欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mysqlin怎么使用 mysql8022怎么使用

mysql查詢 怎么使用 in

in作為查詢條件,一般典型有兩種用法:

成都創(chuàng)新互聯(lián)公司主營高安網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,app軟件開發(fā)公司,高安h5微信小程序搭建,高安網(wǎng)站營銷推廣歡迎高安等地區(qū)企業(yè)咨詢

一是IN常量,例如下面語句查詢一、三年級的學生:

SELECT * FROM student WHERE grade IN ('一','三');

二是使用子查詢,也就是IN(SQL語句),例如下面的語句查詢不及格的班級的所有學生:

SELECT * FROM student WHERE classno IN (

select classno from scores where score60

);

mysql in條件內容過多時處理

mysql的in條件查詢,是括號里拼接逗號相隔的字串,這個字長里的個數(shù)還有限制,網(wǎng)上的說法是1000個,為了避免超出該范圍,可專門封裝一個方法

1.使用exists寫法替代in寫法,exists寫法是使用條件查詢替代in寫法里的一長串字串,這個有時候沒法使用,比如使用第三方接口查學校一年級2千個學生的考試成績,你只知道這些學生的id,沒有更多的關聯(lián)條件

2.使用or的寫法,將in條件過長的字串拆開,mysql支持以下寫法:

方法封裝:

測試效果:

mysql存儲過程 in 怎么用

out 表示輸出的參數(shù),存儲過程調用 代碼 需要獲得此參數(shù)值。

in 表示輸入?yún)?shù),默認為in

例1、一個簡單存儲過程游標實例

復制代碼代碼如下:

DELIMITER $$

DROP PROCEDURE IF EXISTS getUserInfo $$

CREATE PROCEDURE getUserInfo(in date_day datetime)

--

-- 實例

-- 存儲過程名為:getUserInfo

-- 參數(shù)為:date_day日期格式:2008-03-08

--

BEGIN

declare _userName varchar(12); -- 用戶名

declare _chinese int ; -- 語文

declare _math int ; -- 數(shù)學

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; -- 取數(shù)據(jù)

if done=1 then

leave cursor_loop;

end if;

-- 更新表

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

end loop cursor_loop;

close rs_cursor;

END$$

DELIMITER ;

例2、存儲過程游標循環(huán)跳出現(xiàn)

在MySQL的存儲過程中,游標操作時,需要執(zhí)行一個conitnue的操作.眾所周知,MySQL中的游標循環(huán)操作常用的有三種,LOOP,REPEAT,WHILE.三種循環(huán),方式大同小異.以前從沒用過,所以記下來,方便以后查閱.

1.REPEAT

復制代碼代碼如下:

REPEAT

Statements;

UNTIL expression

END REPEAT

demo

DECLARE num INT;

DECLARE my_string VARCHAR(255);

REPEAT

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

SET num = num +1;

UNTIL num 5

END REPEAT;

2.WHILE

復制代碼代碼如下:

WHILE expression DO

Statements;

END WHILE

demo

DECLARE num INT;

DECLARE my_string VARCHAR(255);

SET num =1;

SET str ='';

WHILE num span10DO

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

SET num = num +1;

END WHILE;

3.LOOP(這里面有非常重要的ITERATE,LEAVE)

代碼如下 復制代碼

DECLARE num INT;

DECLARE str VARCHAR(255);

SET num =1;

SET my_string ='';

loop_label: LOOP

IF num 10THEN

LEAVE loop_label;

ENDIF;

SET num = num +1;

IF(num mod3)THEN

ITERATE loop_label;

ELSE

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

ENDIF;

END LOOP;

PS:可以這樣理解ITERATE就是我們程序中常用的contiune,而ITERATE就是break.當然在MySQL存儲過程,需要循環(huán)結構有個名稱,其他都是一樣的.

例3,mysql 存儲過程中使用多游標

先創(chuàng)建一張表,插入一些測試數(shù)據(jù):

復制代碼代碼如下:

DROP TABLE IF EXISTS netingcn_proc_test;

CREATE TABLE `netingcn_proc_test` (

`id` INTEGER(11) NOT NULL AUTO_INCREMENT,

`name` VARCHAR(20),

`password` VARCHAR(20),

PRIMARY KEY (`id`)

)ENGINE=InnoDB;

insert into netingcn_proc_test(name, password) values

('procedure1', 'pass1'),

('procedure2', 'pass2'),

('procedure3', 'pass3'),

('procedure4', 'pass4');下面就是一個簡單存儲過程的例子:

drop procedure IF EXISTS test_proc;

delimiter //

create procedure test_proc()

begin

-- 聲明一個標志done, 用來判斷游標是否遍歷完成

DECLARE done INT DEFAULT 0;

-- 聲明一個變量,用來存放從游標中提取的數(shù)據(jù)

-- 特別注意這里的名字不能與由游標中使用的列明相同,否則得到的數(shù)據(jù)都是NULL

DECLARE tname varchar(50) DEFAULT NULL;

DECLARE tpass varchar(50) DEFAULT NULL;

-- 聲明游標對應的 SQL 語句

DECLARE cur CURSOR FOR

select name, password from netingcn_proc_test;

-- 在游標循環(huán)到最后會將 done 設置為 1

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

-- 執(zhí)行查詢

open cur;

-- 遍歷游標每一行

REPEAT

-- 把一行的信息存放在對應的變量中

FETCH cur INTO tname, tpass;

if not done then

-- 這里就可以使用 tname, tpass 對應的信息了

select tname, tpass;

end if;

UNTIL done END REPEAT;

CLOSE cur;

end

//

delimiter ;

-- 執(zhí)行存儲過程

call test_proc();

需要注意的是變量的聲明、游標的聲明和HANDLER聲明的順序不能搞錯,必須是先聲明變量,再申明游標,最后聲明HANDLER。上述存儲過程的例子中只使用了一個游標,那么如果要使用兩個或者更多游標怎么辦,其實很簡單,可以這么說,一個怎么用兩個就是怎么用的。例子如下:

復制代碼代碼如下:

drop procedure IF EXISTS test_proc_1;

delimiter //

create procedure test_proc_1()

begin

DECLARE done INT DEFAULT 0;

DECLARE tid int(11) DEFAULT 0;

DECLARE tname varchar(50) DEFAULT NULL;

DECLARE tpass varchar(50) DEFAULT NULL;

DECLARE cur_1 CURSOR FOR

select name, password from netingcn_proc_test;

DECLARE cur_2 CURSOR FOR

select id, name from netingcn_proc_test;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

open cur_1;

REPEAT

FETCH cur_1 INTO tname, tpass;

if not done then

select tname, tpass;

end if;

UNTIL done END REPEAT;

CLOSE cur_1;

-- 注意這里,一定要重置done的值為 0

set done = 0;

open cur_2;

REPEAT

FETCH cur_2 INTO tid, tname;

if not done then

select tid, tname;

end if;

UNTIL done END REPEAT;

CLOSE cur_2;

end

//

delimiter ;

call test_proc_1();

上述代碼和第一個例子中基本一樣,就是多了一個游標聲明和遍歷游標。這里需要注意的是,在遍歷第二個游標前使用了set done = 0,因為當?shù)谝粋€游標遍歷玩后其值被handler設置為1了,如果不用set把它設置為 0 ,那么第二個游標就不會遍歷了。當然好習慣是在每個打開游標的操作前都用該語句,確保游標能真正遍歷。當然還可以使用begin語句塊嵌套的方式來處理多個游標,例如:

復制代碼代碼如下:

drop procedure IF EXISTS test_proc_2;

delimiter //

create procedure test_proc_2()

begin

DECLARE done INT DEFAULT 0;

DECLARE tname varchar(50) DEFAULT NULL;

DECLARE tpass varchar(50) DEFAULT NULL;

DECLARE cur_1 CURSOR FOR

select name, password from netingcn_proc_test;

DECLARE cur_2 CURSOR FOR

select id, name from netingcn_proc_test;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

open cur_1;

REPEAT

FETCH cur_1 INTO tname, tpass;

if not done then

select tname, tpass;

end if;

UNTIL done END REPEAT;

CLOSE cur_1;

begin

DECLARE done INT DEFAULT 0;

DECLARE tid int(11) DEFAULT 0;

DECLARE tname varchar(50) DEFAULT NULL;

DECLARE cur_2 CURSOR FOR

select id, name from netingcn_proc_test;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;

open cur_2;

REPEAT

FETCH cur_2 INTO tid, tname;

if not done then

select tid, tname;

end if;

UNTIL done END REPEAT;

CLOSE cur_2;

end;

end

//

delimiter ;

call test_proc_2();

Mysql數(shù)據(jù)查詢in的時候如何排序

前幾天工作上遇到一個問題,在mysql數(shù)據(jù)查詢的時候,使用的是in條件,而結果需要根據(jù)in來進行排序,當時嘗試了幾次都沒成功,后來在度娘的幫助下,找到了解決辦法:

select * from table_name where id in (6,2,1,10,5,7..)

查詢的結果和in中的順序并不一致,也就是說在批量查詢時,mysql的查詢并不是按照in中的值得順序來查詢的。那怎么才能保證和in查詢中的順序相同呢?

查詢了資料發(fā)現(xiàn)有兩種方式可以對in查詢的結果進行排序。一種是order by find_in_set,另外一種是order by substring_index

1、select * from table_name where id in (6,2,1,10,5,7..) order by find_in_set(id,'6,2,1,10,5,7');

2、select * from table_name where id in (6,2,1,10,5,7..)?order by substring_index('6,2,1,10,5,7',id,1);

本文名稱:mysqlin怎么使用 mysql8022怎么使用
鏈接地址:http://chinadenli.net/article46/ddocjeg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供建站公司網(wǎng)站制作商城網(wǎng)站品牌網(wǎng)站設計網(wǎng)站策劃移動網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網(wǎng)站建設