MySql中的存储过程

存储过程如何接收并处理集合类型的参数呢?比如,我想实现id in(ids)类型的操作,该如何实现呢?

此时我们可以把id的集合拼成一个字符串,以字符串的形式传递进来,然后在存储过程里使用WHERE FIND_IN_SET(tbname.field,ids)即可:

#创建数据表
CREATE TABLE grade (
  g_id VARCHAR(100) NOT NULL,
  s_name VARCHAR(100) DEFAULT NULL,
  class_name VARCHAR(100) DEFAULT NULL,
  score VARCHAR(40) DEFAULT NULL,
  PRIMARY KEY (g_id)
);
#初始化数据表
INSERT  INTO grade(g_id,s_name,class_name,score) VALUES ('1','张三','语文','81'),('2','张三','数学','75'),('3','李四','语文','56'),('4','李四','数学','90'),('5','王五','语文','81'),('6','王五','数学','100'),('7','王五','外语','49');

#创建存储过程
DELIMITER //
CREATE PROCEDURE queryGradesInfo(IN ids VARCHAR(100))
BEGIN
    SELECT * FROM grade g WHERE FIND_IN_SET(g.g_id,ids);
END//
DELIMITER ;

#访问存储过程
CALL queryGradesInfo('1,2,3');
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值