欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

mysql查詢用變量,mysql中怎樣對大批量級的數(shù)據(jù)查詢進行優(yōu)化

林國瑞2年前21瀏覽0評論
mysql查詢用變量,mysql中怎樣對大批量級的數(shù)據(jù)查詢進行優(yōu)化?

MySQL 一直以來都支持正則匹配,不過對于正則替換則一直到MySQL 8.0 才支持。對于這類場景,以前要么在MySQL端處理,要么把數(shù)據(jù)拿出來在應(yīng)用端處理。

比如我想把表y1的列str1的出現(xiàn)第3個action的子 串替換成dble,怎么實現(xiàn)?

1. 自己寫SQL層的存儲函數(shù)。代碼如下寫死了3個,沒有優(yōu)化,僅僅作為演示,MySQL 里非常不建議寫這樣的函數(shù)。

mysqlDELIMITER $$USE `ytt`$$DROP FUNCTION IF EXISTS `func_instr_simple_ytt`$$CREATE DEFINER=`root`@`localhost` FUNCTION `func_instr_simple_ytt`(f_str VARCHAR(1000), -- Parameter 1f_substr VARCHAR(100), -- Parameter 2f_replace_str varchar(100),f_times int -- times counter.only support 3.) RETURNS varchar(1000)BEGINdeclare v_result varchar(1000) default 'ytt'; -- result.declare v_substr_len int default 0; -- search string length.set f_times = 3; -- only support 3.set v_substr_len = length(f_substr);select instr(f_str,f_substr) into @p1; -- First real position .select instr(substr(f_str,@p1+v_substr_len),f_substr) into @p2; Secondary virtual position.select instr(substr(f_str,@p2+ @p1 +2*v_substr_len - 1),f_substr) into @p3; -- Third virtual position.if @p1 > 0 && @p2 > 0 && @p3 > 0 then -- Fine.selectconcat(substr(f_str,1,@p1 + @p2 + @p3 + (f_times - 1) * v_substr_len - f_times),f_replace_str,substr(f_str,@p1 + @p2 + @p3 + f_times * v_substr_len-2)) into v_result;elseset v_result = f_str; -- Never changed.end if;-- Purge all session variables.set @p1 = null;set @p2 = null;set @p3 = null;return v_result;end;$$DELIMITER ;-- 調(diào)用函數(shù)來更新:mysql> update y1 set str1 = func_instr_simple_ytt(str1,'action','dble',3);Query OK, 20 rows affected (0.12 sec)Rows matched: 20 Changed: 20 Warnings: 02. 導(dǎo)出來用sed之類的工具替換掉在導(dǎo)入,步驟如下:(推薦使用)1)導(dǎo)出表y1的記錄。mysqlmysql> select * from y1 into outfile '/var/lib/mysql-files/y1.csv';Query OK, 20 rows affected (0.00 sec)2)用sed替換導(dǎo)出來的數(shù)據(jù)。shellroot@ytt-Aspire-V5-471G:/var/lib/mysql-files# sed -i 's/action/dble/3' y1.csv3)再次導(dǎo)入處理好的數(shù)據(jù),完成。mysqlmysql> truncate y1;Query OK, 0 rows affected (0.99 sec)mysql> load data infile '/var/lib/mysql-files/y1.csv' into table y1;Query OK, 20 rows affected (0.14 sec)Records: 20 Deleted: 0 Skipped: 0 Warnings: 0以上兩種還是推薦導(dǎo)出來處理好了再重新導(dǎo)入,性能來的高些,而且還不用自己費勁寫函數(shù)代碼。那MySQL 8.0 對于以上的場景實現(xiàn)就非常簡單了,一個函數(shù)就搞定了。mysqlmysql> update y1 set str1 = regexp_replace(str1,'action','dble',1,3) ;Query OK, 20 rows affected (0.13 sec)Rows matched: 20 Changed: 20 Warnings: 0還有一個regexp_instr 也非常有用,特別是這種特指出現(xiàn)第幾次的場景。比如定義 SESSION 變量@a。mysqlmysql> set @a = 'aa bb cc ee fi lucy 1 1 1 b s 2 3 4 5 2 3 5 561 19 10 10 20 30 10 40';Query OK, 0 rows affected (0.04 sec)拿到至少兩次的數(shù)字出現(xiàn)的第二次子串的位置。mysqlmysql> select regexp_instr(@a,'[:digit:]{2,}',1,2);+--------------------------------------+| regexp_instr(@a,'[:digit:]{2,}',1,2) |+--------------------------------------+| 50 |+--------------------------------------+1 row in set (0.00 sec)那我們在看看對多字節(jié)字符支持如何。mysqlmysql> set @a = '中國 美國 俄羅斯 日本 中國 北京 上海 深圳 廣州 北京 上海 武漢 東莞 北京 青島 北京';Query OK, 0 rows affected (0.00 sec)mysql> select regexp_instr(@a,'北京',1,1);+-------------------------------+| regexp_instr(@a,'北京',1,1) |+-------------------------------+| 17 |+-------------------------------+1 row in set (0.00 sec)mysql> select regexp_instr(@a,'北京',1,2);+-------------------------------+| regexp_instr(@a,'北京',1,2) |+-------------------------------+| 29 |+-------------------------------+1 row in set (0.00 sec)mysql> select regexp_instr(@a,'北京',1,3);+-------------------------------+| regexp_instr(@a,'北京',1,3) |+-------------------------------+| 41 |+-------------------------------+1 row in set (0.00 sec)那總結(jié)下,這里我提到了 MySQL 8.0 的兩個最有用的正則匹配函數(shù) regexp_replace 和 regexp_instr。針對以前類似的場景算是有一個完美的解決方案。