『壹』 mysql 正則表達式查詢
SELECT *
FROM users
WHERE num REGEXP '^[0-9]+$';
『貳』 MYSQL正則匹配,比如查詢ABCABC應該如果寫
我查了資料,寫了這兩個sql
但都不對,感覺還是語法的問題
select*from`a`where`values`REGEXP"(([0-9]){3}){2}"
SELECT*
FROM`a`
WHERE`values`
REGEXP"(([[0-9]){3}]){2}"
//這個sql是可以的,但是太長了
SELECT*
FROM`a`
WHERE`values`
REGEXP'(100|101|102|103|…………|999){2}'
LIMIT0,30
『叄』 mysql 正則 匹配後6位且出現連續3個相同的數字 求高手指點感激不盡。。
select * from phone where phonenumber regexp '[[:digit:]]$';
試試看
抱歉,題目沒看清楚。。
剛查了下mysql的正則表達式文檔,不支持back reference,所以我只能想到用最笨的方法做
select *
from phone where
substring(phonenumber,-1,1) = substring(phonenumber,-2,1) and substring(phonenumber,-3,1) = substring(phonenumber,-4,1) and substring(phonenumber,-1,1) = substring(phonenumber,-4,1)
postgresql資料庫的正則支持back reference。。
『肆』 mysql 正則表達式替換,把指定位置隨機數替換成固定數字
MySQL 一直以來都支持正則匹配,不過對於正則替換則一直到MySQL 8.0 才支持。對於這類場景,以前要麼在MySQL端處理,要麼把數據拿出來在應用端處理。
比如我想把表y1的列str1的出現第3個action的子 串替換成dble,怎麼實現?
1. 自己寫SQL層的存儲函數。代碼如下寫死了3個,沒有優化,僅僅作為演示,MySQL 里非常不建議寫這樣的函數。
mysql
DELIMITER $$
USE `ytt`$$
DROP FUNCTION IF EXISTS `func_instr_simple_ytt`$$
CREATE DEFINER=`root`@`localhost` FUNCTION `func_instr_simple_ytt`(
f_str VARCHAR(1000), -- Parameter 1
f_substr VARCHAR(100), -- Parameter 2
f_replace_str varchar(100),
f_times int -- times counter.only support 3.
) RETURNS varchar(1000)
BEGIN
declare 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.
select
concat(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;
else
set 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 ;
-- 調用函數來更新:
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: 0
2. 導出來用sed之類的工具替換掉在導入,步驟如下:(推薦使用)
1)導出表y1的記錄。
mysqlmysql> select * from y1 into outfile '/var/lib/mysql-files/y1.csv';Query OK, 20 rows affected (0.00 sec)
2)用sed替換導出來的數據。
shellroot@ytt-Aspire-V5-471G:/var/lib/mysql-files# sed -i 's/action/dble/3' y1.csv
3)再次導入處理好的數據,完成。
mysql
mysql> 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
以上兩種還是推薦導出來處理好了再重新導入,性能來的高些,而且還不用自己費勁寫函數代碼。
那MySQL 8.0 對於以上的場景實現就非常簡單了,一個函數就搞定了。
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 也非常有用,特別是這種特指出現第幾次的場景。比如定義 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)
拿到至少兩次的數字出現的第二次子串的位置。
mysqlmysql> select regexp_instr(@a,'[:digit:]{2,}',1,2);+--------------------------------------+| regexp_instr(@a,'[:digit:]{2,}',1,2) |+--------------------------------------+| 50 |+--------------------------------------+1 row in set (0.00 sec)
那我們在看看對多位元組字元支持如何。
mysql
mysql> 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)
那總結下,這里我提到了 MySQL 8.0 的兩個最有用的正則匹配函數 regexp_replace 和 regexp_instr。針對以前類似的場景算是有一個完美的解決方案。
『伍』 mysql正則替換一串數據
update wp_posts set post_content='xxxx' WHERE `mobile` REGEXP 'data-id="0_[0-9]{11,12}"';
先備份小心點。。
『陸』 mysql 正則表達式 ,替換欄位的全部數字
replace(field,'\d','#');
『柒』 mysql 正則表達式 查詢匹配 某個詞
\w是匹配[a-zA-Z0-9] . ? 匹配一個或者0個前面的字元,* 匹配前面0個或者多個字元。
所以這個正則表達式匹配前面具有數字或者字母開頭的,中間為word,後面為數字或者字母結尾的字元串。開頭和結尾不能同時出現字母和數字。
以下幾個例子可匹配:
『捌』 用mysql正則表達式查詢一個號碼欄位是以4個相同數字結尾的結果,這個表達式該怎麼寫
select * from phone where phonenumber regexp '[[:digit:]]{4}$';
試試看
抱歉,題目沒看清楚。。
剛查了下mysql的正則表達式文檔,不支持back reference,所以我只能想到用最笨的方法做
select *
from phone where
substring(phonenumber,-1,1) = substring(phonenumber,-2,1) and substring(phonenumber,-3,1) = substring(phonenumber,-4,1) and substring(phonenumber,-1,1) = substring(phonenumber,-4,1)
postgresql資料庫的正則支持back reference。。
『玖』 mysql替換中的正則表達式如何保留一部分內容
代碼如下:
CREATE PROCEDURE sp_str
(
IN p_str VARCHAR(50), /*原始字元串*/
IN p_begin_str VARCHAR(50), /*要匹配的起始字元串*/
IN p_end_str VARCHAR(50)) /*要匹配的結束字元串*/
OUT p_result VARCHAR(50)) /*返回結果*/
NOT DETERMINISTIC
SQL SECURITY DEFINER
COMMENT ''
BEGIN
DECLARE m_len INT DEFAULT 0;
DECLARE m_index INT DEFAULT 0;
/*計算第一個匹配字元串的索引位置*/
select locate(p_begin_str,p_str)+char_length(p_begin_str) into m_index;
/*計算第一個匹配字元串的長度*/