Maison base de données tutoriel mysql MySQL正则表达式初步_MySQL

MySQL正则表达式初步_MySQL

Jun 01, 2016 pm 01:17 PM
表达式

正则表达式

我们知道,在SQL之中,可以用 like 这个谓词(表达式) 来进行模糊检索,并支持 %,?,_等占位符.
但是,这个模糊检索的功能有很多限制,简单来说就是太模糊了。
在MySQL中提供了 REGEXP 关键字来支持正则表达式,当然,只是一些很简单的正则啦。
首先,我们构造一些测试数据。
-- 建表USE test;DROP TABLE IF EXISTS t_regcustomer;CREATE TABLE t_regcustomer (	id INT(10) AUTO_INCREMENT	,name VARCHAR(256)	,age INT(10)	, PRIMARY KEY(id)) COLLATE='utf8_general_ci' ENGINE=InnoDB;
Copier après la connexion
增加一些测试数据:
-- 插入一些测试数据:TRUNCATE TABLE t_regcustomer;INSERT INTO t_regcustomer(name, age) VALUES ('王明',20);INSERT INTO t_regcustomer(name, age) VALUES ('王大',21);INSERT INTO t_regcustomer(name, age) VALUES ('小王',22);INSERT INTO t_regcustomer(name, age) VALUES ('小王2',22);INSERT INTO t_regcustomer(name, age) VALUES ('敲不死',23);INSERT INTO t_regcustomer(name, age) VALUES ('憨憨',24);INSERT INTO t_regcustomer(name, age) VALUES ('憨憨2',24);INSERT INTO t_regcustomer(name, age) VALUES ('郭靖名',25);INSERT INTO t_regcustomer(name, age) VALUES ('郭靖2',25);INSERT INTO t_regcustomer(name, age) VALUES ('郭靖3',25);INSERT INTO t_regcustomer(name, age) VALUES ('郭得缸',25),('大鹏',20),('大鹏2',20),('大鹏3',20),('二鹏',19),('鹏鹏',18),('鹏鹏1',18),('小鹏',17),('AAA',17),('aaa',17),('SS',17),('s2',17),('ss',17);
Copier après la connexion

1. 最简单的查询:
SELECT *FROM t_regcustomer;
Copier après la connexion
2. 指定列名查询
SELECT c.id, c.name, c.ageFROM t_regcustomer c;
Copier après la connexion
3. 对查询结果排序
SELECT c.id, c.name, c.ageFROM t_regcustomer cORDER BY c.age ASC;
Copier après la connexion
4. like 模糊检索
%匹配任意数量(0~n)的任意字符
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name LIKE '%鹏%'ORDER BY c.age ASC;
Copier après la connexion
5. regexp 关键字
.匹配任意一个字符
注意此处因为没有起始(^)和结束($)限定符,所以只要列中出现的行都会被检索出来.
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name REGEXP '.鹏.'ORDER BY c.age ASC;
Copier après la connexion
6. 正则起始限定符
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name REGEXP '^王'ORDER BY c.age ASC;
Copier après la connexion
7. 大小写敏感
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name REGEXP BINARY '^s'ORDER BY c.age ASC;
Copier après la connexion
8. 正则或运算
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name REGEXP BINARY 'a|s'ORDER BY c.name ASC;
Copier après la connexion
9. 组运算正则
[123] 表示 1、2、3这3个数字之一出现即可
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name REGEXP BINARY '鹏[123]'ORDER BY c.name ASC;
Copier après la connexion
[1-9] 匹配 1、2、3、.... 8、9
SELECT c.id, c.name, c.ageFROM t_regcustomer cWHERE c.name REGEXP BINARY '鹏[1-9]'ORDER BY c.name ASC;
Copier après la connexion
10. 转义
使用 //
可以转义 /.[]()?-| 以及分页,换行符号等

11.更多内容

请查阅 《MySQL必知必会》 68页 正则表达式


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment résoudre les erreurs de syntaxe des expressions Python ? Comment résoudre les erreurs de syntaxe des expressions Python ? Jun 24, 2023 pm 05:04 PM

Python, en tant que langage de programmation de haut niveau, est facile à apprendre et à utiliser. Une fois que vous aurez besoin d’écrire un programme Python, vous rencontrerez inévitablement des erreurs de syntaxe, et les erreurs de syntaxe d’expression sont courantes. Dans cet article, nous verrons comment résoudre les erreurs de syntaxe d’expression en Python. Les erreurs de syntaxe d'expression sont l'une des erreurs les plus courantes en Python et elles sont généralement causées par une utilisation incorrecte de la syntaxe ou par des composants nécessaires manquants. En Python, les expressions sont généralement constituées de nombres, de chaînes, de variables et d'opérateurs. le plus courant

En C et C++, la virgule est utilisée pour séparer les expressions ou les instructions En C et C++, la virgule est utilisée pour séparer les expressions ou les instructions Sep 09, 2023 pm 05:33 PM

En C ou C++, la virgule "," a différentes utilisations. Ici, nous apprendrons comment les utiliser. Virgules comme opérateurs. L'opérateur virgule est un opérateur binaire qui évalue le premier opérande, ignore le résultat, puis évalue le deuxième opérande et renvoie la valeur. L'opérateur virgule a la priorité la plus basse en C ou C++. Exemple #include<stdio.h>intmain(){ intx=(50,60); inty=(func1(),func2());} Ici, 60 sera attribué à x. Pour l'instruction suivante, func1( sera exécuté en premier

Introduction aux expressions de fonctions exponentielles en langage C Introduction aux expressions de fonctions exponentielles en langage C Feb 18, 2024 pm 01:11 PM

Introduction à la façon d'écrire des expressions de fonctions exponentielles en langage C et exemples de code Qu'est-ce qu'une fonction exponentielle ? La fonction exponentielle est un type courant de fonction en mathématiques. Elle peut être exprimée sous la forme f(x)=a^x, où. a est la base et x est l'exposant. Les fonctions exponentielles sont principalement utilisées pour décrire la croissance exponentielle ou la décroissance exponentielle. Exemple de code de fonction exponentielle En langage C, nous pouvons utiliser la fonction pow() dans la bibliothèque mathématique pour calculer la fonction exponentielle. Voici un exemple de programme : #include.

expression lambda en Java expression lambda en Java Jun 09, 2023 am 10:17 AM

Expressions lambda en Java Avec la sortie de Java 8, les expressions lambda sont devenues l'un des sujets les plus préoccupants et discutés parmi les développeurs Java. Les expressions Lambda peuvent simplifier les méthodes d'écriture fastidieuses des programmeurs Java et peuvent également améliorer la lisibilité et la maintenabilité des programmes. Dans cet article, nous examinerons en profondeur les expressions lambda en Java et comment elles offrent une expérience de programmation plus simple et plus intuitive dans le code Java.

Boucler sur une collection à l'aide d'expressions lambda Boucler sur une collection à l'aide d'expressions lambda Feb 19, 2024 pm 07:32 PM

Une expression lambda est une fonction anonyme qui peut être facilement utilisée pour parcourir une collection. Dans cet article, nous présenterons comment utiliser les expressions lambda pour parcourir des collections et fournirons des exemples de code spécifiques. En Python, le format syntaxique d'une expression lambda est le suivant : Liste de paramètres lambda : La liste de paramètres d'une expression expression lambda peut contenir un ou plusieurs paramètres, séparés par des virgules. L'expression est la valeur de retour de la fonction lambda. Regardons un exemple simple ci-dessous, en supposant

Guide avancé des expressions Python Lambda : du débutant à la maîtrise Guide avancé des expressions Python Lambda : du débutant à la maîtrise Feb 24, 2024 pm 03:31 PM

Introduction et syntaxe de base des expressions Lambda Les expressions Lambda se composent d'une liste de paramètres de fonction, de deux points et d'un corps de fonction. La liste des paramètres de la fonction est la même que celle d'une fonction ordinaire et le corps de la fonction est une expression plutôt qu'un ensemble d'instructions. #Exemple : renvoie une fonction qui reçoit deux nombres et renvoie leur somme sum=lambdax,y:x+y Scénarios d'application des expressions Lambda Les expressions Lambda sont très adaptées pour être utilisées comme fonctions de rappel, fonctions de filtrage et fonctions de mappage. Fonction de rappel : Une fonction de rappel est une fonction appelée dans une autre fonction. Les expressions Lambda facilitent la création de fonctions de rappel sans déclarer leurs noms. Fonction de filtre : la fonction de filtre est utilisée pour filtrer complètement

Expression Java Lambda en pratique : percer les mystères de la programmation fonctionnelle avec du code Expression Java Lambda en pratique : percer les mystères de la programmation fonctionnelle avec du code Feb 26, 2024 am 10:25 AM

L'expression Lambda, comme son nom l'indique, est une fonction anonyme avec le symbole de flèche (->) comme noyau. Il vous permet de transmettre des blocs de code comme arguments à d'autres méthodes ou de les stocker dans des variables pour une utilisation ultérieure. La syntaxe des expressions Lambda est concise et facile à comprendre, et elle est très adaptée au traitement des flux de données et au calcul parallèle. 1. La syntaxe de base de l'expression Lambda La syntaxe de base de l'expression Lambda est la suivante : (liste de paramètres) -> {bloc de code} Parmi eux, la liste de paramètres et le bloc de code sont facultatifs. S'il n'y a qu'un seul paramètre, les parenthèses peuvent être omises. Si le bloc de code ne comporte qu’une seule ligne, les accolades peuvent être omises. Par exemple, le bloc de code suivant utilise une expression Lambda pour ajouter 1 à un nombre : Liste

Le bloc d'instructions try dans PHP8.0 prend en charge les expressions Le bloc d'instructions try dans PHP8.0 prend en charge les expressions May 14, 2023 am 08:12 AM

Avec le développement rapide de la technologie informatique, les langages de programmation sont constamment mis à niveau et améliorés. Parmi eux, PHP, en tant que langage de développement Web couramment utilisé, innove et lance constamment de nouvelles versions. Récemment, la sortie de la version PHP8.0 a attiré une large attention. Parmi elles, les améliorations apportées au mécanisme de gestion des exceptions dans la nouvelle version ont attiré beaucoup d'attention. Cet article se concentrera sur le sujet de la prise en charge des expressions dans le bloc d'instructions try de PHP8.0. 1. Améliorations du mécanisme de gestion des exceptions de PHP8.0 Dans les versions précédentes, P

See all articles