网站首页 > 文章中心 > 其它

mysql中in怎么传值

作者:小编 更新时间:2023-09-27 07:33:33 浏览量:487人看过

mysql存储过程中in传的变量有多个

sql语句:

复制代码代码示例:

当在写存储过程in中的列表用个传入参数代入时,可以使用如下的方式.

以下代码使用find_in_set函数:

mysql中in怎么传值-图1

另外一个广场,就是组装字符串,然后执行:

DROP PROCEDURE IF EXISTS photography.Proc_Test;

CREATE PROCEDURE photography.+Proc_Test+(param1 varchar(1000))

BEGIN

set @id = param1;

set @sel = 'select * from access_record t where t.ID in (';

prepare stmt from @sentence; -- 预编释一下. "stmt"预编释变量的名称,

execute stmt; -- 执行SQL语句

deallocate prepare stmt; -- 释放

mysql 字段为多个值怎么用in

insert into test_city values(1);

mysql 中where in怎么传字符串进去给In

mysql 中 in的用法

①in 后面是记录集,如:

select?*?from?table?where?uname?in(select?uname?from?user);

select?*?from?table?where?uname?in('aaa',bbb','ccc','ddd','eee',ffff'');

注意:这里一定要将字符串用单引号'' 标注起来;

//$pieces是含数据的数组

for($i=0;$icount($pieces);$i++){

$uname=$uname."'".$pieces[$i]."',";

}

$the_uname?="uname?in(".$uname."'')";

select?*?from?table?where?".$the_uname."?;

mysql存储过程 in 怎么用

out 表示输出的参数,存储过程调用 代码 需要获得此参数值.

in 表示输入参数,默认为in

例1、一个简单存储过程游标实例

复制代码代码如下:

DELIMITER $$

DROP PROCEDURE IF EXISTS getUserInfo $$

CREATE PROCEDURE getUserInfo(in date_day datetime)

--

-- 实例

-- 存储过程名为:getUserInfo

declare _chinese int ; -- 语文

declare _math int ; -- 数学

declare done int;

-- 定义游标

DECLARE rs_cursor CURSOR FOR SELECT username,chinese,math from userInfo where datediff(createDate, date_day)=0;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;

-- 获取昨天的日期

if date_day is null then

set date_day = date_add(now(),interval -1 day);

end if;

open rs_cursor;

cursor_loop:loop

FETCH rs_cursor into _userName, _chinese, _math; -- 取数据

if done=1 then

leave cursor_loop;

-- 更新表

update infoSum set total=_chinese+_math where UserName=_userName;

end loop cursor_loop;

close rs_cursor;

END$$

DELIMITER ;

在MySQL的存储过程中,游标操作时,需要执行一个conitnue的操作.众所周知,MySQL中的游标循环操作常用的有三种,LOOP,REPEAT,WHILE.三种循环,方式大同小异.以前从没用过,所以记下来,方便以后查阅.

①REPEAT

REPEAT

Statements;

UNTIL expression

END REPEAT

demo

DECLARE num INT;

SET my_string =CONCAT(my_string,num,',');

SET num = num +1;

END REPEAT;

WHILE expression DO

END WHILE

SET num =1;

SET str ='';

WHILE num span10DO

END WHILE;

代码如下 复制代码

DECLARE num INT;

SET my_string ='';

loop_label: LOOP

IF num 10THEN

LEAVE loop_label;

ENDIF;

ITERATE loop_label;

ELSE

END LOOP;

PS:可以这样理解ITERATE就是我们程序中常用的contiune,而ITERATE就是break.当然在MySQL存储过程,需要循环结构有个名称,其他都是一样的.

先创建一张表,插入一些测试数据:

DROP TABLE IF EXISTS netingcn_proc_test;

CREATE TABLE +netingcn_proc_test+ (

+id+ INTEGER(11) NOT NULL AUTO_INCREMENT,

PRIMARY KEY (+id+)

)ENGINE=InnoDB;

insert into netingcn_proc_test(name, password) values

('procedure1', 'pass1'),

drop procedure IF EXISTS test_proc;

delimiter //

create procedure test_proc()

begin

-- 声明一个标志done, 用来判断游标是否遍历完成

DECLARE done INT DEFAULT 0;

-- 声明一个变量,用来存放从游标中提取的数据

-- 特别注意这里的名字不能与由游标中使用的列明相同,否则得到的数据都是NULL

-- 声明游标对应的 SQL 语句

DECLARE cur CURSOR FOR

select name, password from netingcn_proc_test;

-- 在游标循环到最后会将 done 设置为 1

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

-- 执行查询

open cur;

-- 遍历游标每一行

-- 把一行的信息存放在对应的变量中

FETCH cur INTO tname, tpass;

if not done then

-- 这里就可以使用 tname, tpass 对应的信息了

select tname, tpass;

UNTIL done END REPEAT;

CLOSE cur;

end

//

delimiter ;

-- 执行存储过程

call test_proc();

需要注意的是变量的声明、游标的声明和HANDLER声明的顺序不能搞错,必须是先声明变量,再申明游标,最后声明HANDLER.上述存储过程的例子中只使用了一个游标,那么如果要使用两个或者更多游标怎么办,其实很简单,可以这么说,一个怎么用两个就是怎么用的.例子如下:

drop procedure IF EXISTS test_proc_1;

create procedure test_proc_1()

DECLARE tid int(11) DEFAULT 0;

DECLARE cur_1 CURSOR FOR

select id, name from netingcn_proc_test;

open cur_1;

FETCH cur_1 INTO tname, tpass;

CLOSE cur_1;

-- 注意这里,一定要重置done的值为 0

set done = 0;

select tid, tname;

call test_proc_1();

上述代码和第一个例子中基本一样,就是多了一个游标声明和遍历游标.这里需要注意的是,在遍历第二个游标前使用了set done = 0,因为当第一个游标遍历玩后其值被handler设置为1了,如果不用set把它设置为 0 ,那么第二个游标就不会遍历了.当然好习惯是在每个打开游标的操作前都用该语句,确保游标能真正遍历.当然还可以使用begin语句块嵌套的方式来处理多个游标,例如:

end;

以上就是土嘎嘎小编为大家整理的mysql中in怎么传值相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章