簡體   English   中英

REGEX_REPLACE in mySQL 字符內的所有內容及其值

[英]REGEX_REPLACE in mySQL everything inside character with its value

我想使用 REGEX_REPLACE 替換 mysql 中的文本字段。

我的字符串看起來像這樣:

Hi friends @[Friendly User <user@contoso.com>], what are you doing?

我想要的是,刪除方括號[]內的所有內容,除了<>內的文本。

所以 output 應該是這樣的:

Hi friends @user@contoso.com, what are you doing?

我的 SQL 代碼:

UPDATE `Chat`
SET `Text` = REGEXP_REPLACE(`Text`, '\<(.*?)\>', 'text inside <>');

鏈接到 dbfiddle:

https://dbfiddle.uk/?rdbms=mariadb_10.5&fiddle=f930852c6bf05fbb31125f42852093f9

UPDATE `Chat`
SET `Text` = REGEXP_REPLACE(`Text`, '\\[.*\<(.*?)\>.*\\]', '\\1');

\\1是轉義的\1以引用第一個捕獲組值。 您可以使用它來引用替換中捕獲的值。 我也修改了您的正則表達式以匹配括號。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM