MySQL存储过程不会抓取整个表?
你可以在存储过程中使用 SELECT *FROM yourTableName。我们先创建一个表 −
mysql> create table DemoTable654 ( StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY,StudentFirstName varchar(100) ); Query OK, 0 rows affected (0.70 sec)
在表中插入一些记录使用 insert 命令 −
mysql> insert into DemoTable654(StudentFirstName) values('John'); Query OK, 1 row affected (0.11 sec) mysql> insert into DemoTable654(StudentFirstName) values('Sam'); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable654(StudentFirstName) values('Mike'); Query OK, 1 row affected (0.15 sec) mysql> insert into DemoTable654(StudentFirstName) values('Robert'); Query OK, 1 row affected (0.12 sec)
使用 select 语句显示表中所有记录 −
mysql> select *from DemoTable654;
这将生成如下输出 −
+-----------+------------------+ | StudentId | StudentFirstName | +-----------+------------------+ | 1 | John | | 2 | Sam | | 3 | Mike | | 4 | Robert | +-----------+------------------+ 4 rows in set (0.00 sec)
以下是使用存储过程抓取整个表记录的查询 −
mysql> DELIMITER // mysql> CREATE PROCEDURE getWholeTable() BEGIN SELECT *FROM DemoTable654; END // Query OK, 0 rows affected (0.16 sec) mysql> DELIMITER ;
现在,可以使用 call 命令调用上述存储过程 −
mysql> call getWholeTable();
这将生成如下输出 −
+-----------+------------------+ | StudentId | StudentFirstName | +-----------+------------------+ | 1 | John | | 2 | Sam | | 3 | Mike | | 4 | Robert | +-----------+------------------+ 4 rows in set (0.08 sec) Query OK, 0 rows affected (0.13 sec)
广告