Cet article présente principalement l'utilisation du remplacement et de l'expression rationnelle dans MySQL pour remplacer l'expression régulière, et analyse les techniques d'utilisation et les techniques du remplacement et de l'expression régulière regexp en combinaison avec des exemples spécifiques . Pour des notes connexes, les amis dans le besoin peuvent se référer à
Cet article décrit l'utilisation de replace et regexp pour le remplacement d'expressions régulières dans MySQL. Partagez-le avec tout le monde pour référence, les détails sont les suivants :
Aujourd'hui, un ami m'a demandé si je pouvais modifier tous les formats similaires à "./uploads/110100_cityHotel_Beijing Fu Luxury Hotel.jpg" trouvés dans la base de données. Il est au format "./uploads/110100cityHotelBeijing Fu Luxury Hotel.jpg". Je n'ai jamais traité les données de cette manière, mais je sais que MySQL peut utiliser le remplacement et que les expressions régulières peuvent également le faire.
Comment faire ?
Nous n'avons besoin que d'une telle déclaration,
Le code est le suivant :
update master_data.md_employee set name=replace(name,"_",'') where id = 825;
-- note replace (Nom du champ, "Caractères à remplacer", "Caractères à remplacer"), ça y est.
Dans Mysql, le remplacement et l'expression rationnelle réalisent principalement le remplacement des données via des instructions SQL.
Parlons d’abord de l’utilisation spécifique de replace.
Utilisation du remplacement de mysql
1.replace into
Le code est le suivant :
replace into table (id,name) values('1′,'aa'),('2′,'bb')
Cette instruction La fonction est d'insérer deux enregistrements dans la table. Si l'identifiant de la clé primaire est 1 ou 2 et n'existe pas,
est équivalent à
Le code est le suivant :
insert into table (id,name) values('1′,'aa'),('2′,'bb')
remplace(<a href="//m.sbmmt.com/wiki /60.html" target="_blank" >object<p>,search,replace)
replace(<a href="//m.sbmmt.com/wiki/60.html" target="_blank">object</a>,search,replace)
Remplacez toutes les occurrences de recherche dans l'objet par replaceselect replace('www.jb51.net','w','Ww')
update table set name=replace(name,'aa','bb')
AutresType utilise des expressions régulières étendues.
Lorsque vous testez des correspondances sur de tels modèles, utilisez les opérateurs REGEXP et NOT REGEXP (ou RLIKE et NOT RLIKE, qui sont des synonymes).
Certains caractères qui étendent les expressions régulières sont :· « . » correspond à n'importe quel caractère.
· " * " correspond à zéro ou plusieurs caractères qui le précèdent. Par exemple, "x*" correspond à n'importe quel nombre de caractères "x", "[0-9]*" correspond à n'importe quel nombre de chiffres et ".*" correspond à n'importe quel nombre de caractères.
Le modèle correspond si le modèle REGEXP correspond n'importe où dans la valeur testée (ceci est différent de la correspondance de modèle LIKE, qui correspond uniquement à la valeur entière).
Pour positionner un motif de manière à ce qu'il corresponde au début ou à la fin de la valeur testée, utilisez "^" au début du motif ou "$" à la fin du modèle.
Pour illustrer le fonctionnement des expressions régulières étendues, réécrivons la requête LIKEprésentée ci-dessus en utilisant REGEXP :
1. Afin de découvrir ce qui commence par " d Pour les noms commençant par ", utilisez "^" pour faire correspondre le début du nom :SELECT * FROM master_data.md_employee WHERE name REGEXP '^d';
chaînes en chaîne binaire. Cette requête correspond uniquement à la première lettre du nom, « d » minuscule.
SELECT * FROM master_data.md_employee WHERE name REGEXP BINARY'^d';
SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'love$';
SELECT id,name FROM master_data.md_employee WHERE name REGEXP 'w';
Le code est le suivant :
SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.....$';
你也可以使用“{n}”“重复n次”操作符重写前面的查询:
代码如下:
SELECT id,name FROM master_data.md_employee WHERE name REGEXP '^.{5}$';
这些知识一些简单的mysql的replace和regexp的用法,对于深入的学习,我们会在之后的文章会将具体的例子以及用法写出
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!