MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

列の値をMySQLストアドプロシージャの変数に格納します


変数を宣言するには、MySQLストアドプロシージャでDECLAREを使用します。まずテーブルを作成しましょう-

mysql> create table DemoTable2034
   -> (
   -> StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   -> StudentName varchar(20),
   -> StudentAge int
   -> );
Query OK, 0 rows affected (0.49 sec)
>

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable2034(StudentName,StudentAge) values('Chris',23);
Query OK, 1 row affected (0.10 sec)

mysql> insert into DemoTable2034(StudentName,StudentAge) values('David',21);
Query OK, 1 row affected (0.15 sec)

mysql> insert into DemoTable2034(StudentName,StudentAge) values('Robert',25);
Query OK, 1 row affected (0.15 sec)

mysql> insert into DemoTable2034(StudentName,StudentAge) values('Mike',19);
Query OK, 1 row affected (0.14 sec)

selectステートメントを使用してテーブルのすべてのレコードを表示する-

mysql> select *from DemoTable2034;

これにより、次の出力が生成されます-

+-----------+-------------+------------+
| StudentId | StudentName | StudentAge |
+-----------+-------------+------------+
| 1         | Chris       | 23         |
| 2         | David       | 21         |
| 3         | Robert      | 25         |
| 4         | Mike        | 19         |
+-----------+-------------+------------+
4 rows in set (0.00 sec)

これは、ストアドプロシージャを作成し、上記のテーブルの列の値をストアドプロシージャ変数に格納するためのクエリです-

mysql> delimiter //
mysql> create procedure select_into_variable(id int)
   -> begin
   -> declare name varchar(50);
   -> select StudentName into name from DemoTable2034 where StudentId=id;
   -> select concat('Your Name is= ',name);
   -> end
   -> //
Query OK, 0 rows affected (0.09 sec)
mysql> delimiter ;

ストアドプロシージャを呼び出す-

mysql> call select_into_variable(4);

これにより、次の出力が生成されます-

+-------------------------------+
| concat('Your Name is= ',name) |
+-------------------------------+
| Your Name is= Mike            |
+-------------------------------+
1 row in set (0.04 sec)
Query OK, 0 rows affected (0.06 sec)

  1. Javaを使用してDATEをMySQL列の値に挿入するにはどうすればよいですか?

    このために、JavaのPreparedStatementを使用できます。まず、列の1つがDATE型のArrivalDateであるテーブルを作成しましょう- mysql> create table DemoTable(    PassengerId int,    PassengerName varchar(40),    ArrivalDate date ); Query OK, 0 rows affected (0.82 sec) 日付を挿入するためのJAVAコードは次のとおりです- import java.sql.Conn

  2. MySQLストアドプロシージャでNULLまたは空の変数を確認します

    NULLまたは空の変数をチェックするには、IF条件を使用します。ストアドプロシージャを作成しましょう- mysql> delimiter // mysql> create procedure checkingForNullDemo(Name varchar(20))      begin      if Name is NULL OR Name='' then      select 'Adam Smith';      else