MySQL字符串与字符串比较函数学习
在mysql数据库中字符串在数据库中占有很重要的地位,下面我来介绍MySQL字符串比较函数的一些基础学习,有需要的朋友可参考一下。
1:字符串连接函数
代码如下 | 复制代码 |
CONCAT(str1,str2,...) |
返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。或许有一个或多个参数。 如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast, 例如: SELECT CONCAT(CAST(int_col AS CHAR), char_col)
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT CONCAT('My', 'S', 'QL'); mysql> SELECT CONCAT('My', NULL, 'QL'); mysql> SELECT CONCAT(14.3); |
下面这个concat_ws是concat的变体:
CONCAT_WS(separator,str1,str2,...)
CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。 第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT CONCAT_WS(',','First name','Second name','Last Name'); mysql> SELECT CONCAT_WS(',','First name',NULL,'Last Name'); |
CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。
这个函数和php的explode和implode、list、extract相似了。有兴趣的可以看看php的手册。
2:字符串剪接函数
INSERT(str,pos,len,newstr)
这个函数,mysql中文手册翻译得太烂了,还是偶自己来吧:
这个函数返回一个字符串:
A:str字符串从位置pos(从1开始计算)开始(含第pos位),之后的pos位被字符串newstr取代;
B:如果pos大于str的长度,则从str后面开始衔接;
C:如果因len超出余后的长度,则位置pos之后(含第pos位)全被取代;
D:如果pos为负数,返回str;
E:如果len为负数,则情同len超出余后的长度,这和php的substr之类的函数不一样。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT INSERT('Quadratic', 3, 4, 'What'); mysql> SELECT INSERT('Quadratic', -1, 4, 'What'); mysql> SELECT INSERT('Quadratic', 3, 100, 'What'); |
这个函数支持多字节字元。
3:进制转换函数
CONV(N,from_base,to_base)
不同数基间转换数字。返回值为数字的N字符串表示,由from_base基转化为 to_base 基。如有任意一个参数为NULL,则返回值为 NULL。自变量 N 被理解为一个整数,但是可以被指定为一个整数或字符串。最小基数为 2 ,而最大基数则为 36。 If to_base 是一个负数,则 N 被看作一个带符号数。否则, N 被看作无符号数。 CONV() 的运行精确度为 64比特。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT CONV('a',16,2); -> '1010' mysql> SELECT CONV('6E',18,8); -> '172' mysql> SELECT CONV(-17,10,-18); -> '-H' mysql> SELECT CONV(10+'10'+'10'+0xa,10,10); -> '40' |
请看PHP的:
base_convert — 在任意进制之间转换数字
说明:
string base_convert ( string $number , int $frombase , int $tobase )
返回一字符串,包含 number 以 tobase 进制的表示。number 本身的进制由 frombase 指定。frombase 和 tobase 都只能在 2 和 36 之间(包括 2 和 36)。高于十进制的数字用字母 a-z 表示,例如 a 表示 10,b 表示 11 以及 z 表示 35。
MySQL的进制转换函数还有一个,是一个为16进制而定义的函数:
HEX(N_or_S)
如果N_OR_S 是一个数字,则返回一个 十六进制值 N 的字符串表示,在这里, N 是一个longlong (BIGINT)数。这相当于 CONV(N,10,16)。
如果N_OR_S 是一个字符串,则返回值为一个N_OR_S的十六进制字符串表示, 其中每个N_OR_S 里的每个字符被转化为两个十六进制数字。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT HEX(255); |
4:字符查找定位函数
ELT(N,str1,str2,str3,...)
若N = 1,则返回值为 str1 ,若N = 2,则返回值为 str2 ,以此类推。 若N 小于1或大于参数的数目,则返回值为 NULL 。 ELT() 是 FIELD()的补数。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT ELT(1, 'ej', 'Heja', 'hej', 'foo'); |
看见上面这个函数,还以为主要起逻辑判断用的,如:
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT ELT(if(1, 2, 3), 'ej', 'Heja', 'hej', 'foo'); +----------------------------------------------+ | ELT(if(1, 2, 3), 'ej', 'Heja', 'hej', 'foo') | +----------------------------------------------+ | Heja | +----------------------------------------------+ 1 row in set (0.00 sec) |
但是一看下面的函数,才明白不仅仅如此:
FIELD(str,str1,str2,str3,...)
返回值为str1, str2, str3,……列表中的str 指数。在找不到str 的情况下,返回值为 0 。
如果所有对于FIELD() 的参数均为字符串,则所有参数均按照字符串进行比较。如果所有的参数均为数字,则按照数字进行比较。否则,参数按照双倍进行比较。
如果str 为NULL,则返回值为0 ,原因是NULL不能同任何值进行同等比较。FIELD() 是ELT()的补数。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT FIELD('ej', 'Hej', 'ej', 'Heja', 'hej', 'foo'); -> 2 mysql> SELECT FIELD('fo', 'Hej', 'ej', 'Heja', 'hej', 'foo'); -> 0 |
这个函数与php中的array_search和array_key_exists、in_array、isset还是有相似作用的。
再看一下下面这个,不禁拍案叫绝了,直接就是in子句了:
FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT FIND_IN_SET('b','a,b,c,d'); |
5:数字格式化函数
FORMAT(X,D)
将数字X 的格式写为'#,###,###.##',以四舍五入的方式保留小数点后 D 位, 并将结果以字符串的形式返回。若 D 为 0, 则返回结果不带有小数点,或不含小数部分。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT FORMAT(12332.123456, 4); -> '12,332.1235' mysql> SELECT FORMAT(12332.1,4); -> '12,332.1000' mysql> SELECT FORMAT(12332.2,0); -> '12,332' |
字符串比较中有以下四个规则:
1:MySQL 会自动将数字转化为字符串,反之亦然。
2:若想要将数字明确地转化为字符串,可使用 CAST()或 CONCAT()函数。
3:若已经对一个字符串函数给定一个二进制字符串作为参数, 则所得到的结果字符串也是一个二进制字符串。
4:一般而言, 若字符串比较中任意一个表达式是区分大小写的,则执行比较时也区分大小写。
下面根据以上说的三类进行学习:
一:使用like子句
expr LIKE pat [ESCAPE 'escape-char']
模式匹配,使用SQL简单正规表达式比较。返回1 (TRUE) 或 0 (FALSE)。 若 expr 或 pat 中任何一个为 NULL,则结果为 NULL。
模式不需要为文字字符串。例如,可以被指定为一个字符串表达式或表列。
在模式中可以同LIKE一起使用以下两种通配符:
字符
说明
%
匹配任何数目的字符,甚至包括零字符
_
只能匹配一种字符
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT 'David!' LIKE 'David_'; mysql> SELECT 'David!' LIKE '%D%v%'; |
若要对通配符的文字实例进行检验, 可将转义字符放在该字符前面。如果没有指定 ESCAPE字符, 则假设为‘’。这个和一般的编程语言是一样的。
字符串
说明
%
匹配一个 ‘%’字符
_
匹配一个 ‘_’ 字符
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT 'David!' LIKE 'David_'; mysql> SELECT 'David_' LIKE 'David_'; |
也可以指定一个不同的转义字符,需使用ESCAPE语句:
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT 'David_' LIKE 'David|_' ESCAPE '|'; -> 1 |
以下两个语句举例说明了字符串比较不区分大小写,除非其中一个操作数为二进制字符串:
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT 'abc' LIKE 'ABC'; mysql> SELECT 'abc' LIKE BINARY 'ABC'; |
在MySQL中, LIKE 允许出现在数字表达式中。 (这是标准SQL LIKE 的延伸)。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT 10 LIKE '1%'; |
注释: 由于 MySQL在字符串中使用 C转义语法(例如, 用‘n’代表一个换行字符),在LIKE字符串中,必须将用到的‘’双写。例如, 若要查找 ‘n’, 必须将其写成 ‘\n’。而若要查找 ‘’, 则必须将其写成 it as ‘\\’;原因是反斜线符号会被语法分析程序剥离一次,在进行模式匹配时,又会被剥离一次,最后会剩下一个反斜线符号接受匹配。
二:使用正则表达式的like子句
expr REGEXP pat expr RLIKE pat
执行字符串表达式 expr 和模式pat 的模式匹配。该模式可以被延伸为正则表达式。正则表达式的语法在附录G:MySQL正则表达式中有详细讨论。若expr 匹配 pat,则返回 1; 否则返回0。若 expr 或 pat 任意一个为 NULL, 则结果为 NULL。 RLIKE 是REGEXP的同义词, 作用是为mSQL 提供兼容性。
模式不需要为文字字符串。例如,可以被指定为一个字符串表达式或表列。
注释:由于在字符串中, MySQL使用 C 转义语法 (例如, 用‘n’来代表换行字符 ),在REGEXP字符串中必须将用到的‘’ 双写。
REGEXP 不区分大小写, 除非将其同二进制字符串同时使用。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT 'Monty!' REGEXP 'm%y%%'; mysql> SELECT 'Monty!' REGEXP '.*'; mysql> SELECT 'new*n*line' REGEXP 'new\*.\*line'; mysql> SELECT 'a' REGEXP 'A', 'a' REGEXP BINARY 'A'; mysql> SELECT 'a' REGEXP '^[a-d]'; |
在确定字符类型时,REGEXP 和 RLIKE 使用当前字符集 (默认为cp1252 Latin1 )。 警告:这些操作符不支持多字节字元。
三:使用函数:STRCMP
STRCMP(expr1,expr2)
若所有的字符串均相同,则返回0;若根据当前分类次序,第一个参数小于第二个,则返回 -1,其它情况返回 1 。
以下是代码片段:
代码如下 | 复制代码 |
mysql> SELECT STRCMP('text', 'text2'); mysql> SELECT STRCMP('text2', 'text'); mysql> SELECT STRCMP('text', 'text'); |
在执行比较时,STRCMP() 使用当前字符集。这使得默认的比较区分大小写,当操作数中的一个或两个都是二进制字符串时除外。
说明:对于前两个都有其反操作。见下
代码如下 | 复制代码 |
expr NOT LIKE pat [ESCAPE 'escape-char'] expr NOT REGEXP pat expr NOT RLIKE pat |

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Dans la base de données MySQL, la relation entre l'utilisateur et la base de données est définie par les autorisations et les tables. L'utilisateur a un nom d'utilisateur et un mot de passe pour accéder à la base de données. Les autorisations sont accordées par la commande Grant, tandis que le tableau est créé par la commande Create Table. Pour établir une relation entre un utilisateur et une base de données, vous devez créer une base de données, créer un utilisateur, puis accorder des autorisations.

MySQL convient aux débutants car il est simple à installer, puissant et facile à gérer les données. 1. Installation et configuration simples, adaptées à une variété de systèmes d'exploitation. 2. Prise en charge des opérations de base telles que la création de bases de données et de tables, d'insertion, d'interrogation, de mise à jour et de suppression de données. 3. Fournir des fonctions avancées telles que les opérations de jointure et les sous-questionnaires. 4. Les performances peuvent être améliorées par l'indexation, l'optimisation des requêtes et le partitionnement de la table. 5. Prise en charge des mesures de sauvegarde, de récupération et de sécurité pour garantir la sécurité et la cohérence des données.

Navicat lui-même ne stocke pas le mot de passe de la base de données et ne peut récupérer que le mot de passe chiffré. Solution: 1. Vérifiez le gestionnaire de mots de passe; 2. Vérifiez la fonction "Remember Motway" de Navicat; 3. Réinitialisez le mot de passe de la base de données; 4. Contactez l'administrateur de la base de données.

1. Utilisez l'index correct pour accélérer la récupération des données en réduisant la quantité de données numérisées SELECT * FROMMLOYEESEESHWHERELAST_NAME = 'SMITH'; Si vous recherchez plusieurs fois une colonne d'une table, créez un index pour cette colonne. If you or your app needs data from multiple columns according to the criteria, create a composite index 2. Avoid select * only those required columns, if you select all unwanted columns, this will only consume more server memory and cause the server to slow down at high load or frequency times For example, your table contains columns such as created_at and updated_at and timestamps, and then avoid selecting * because they do not require inefficient query se

Créez une base de données à l'aide de NAVICAT Premium: Connectez-vous au serveur de base de données et entrez les paramètres de connexion. Cliquez avec le bouton droit sur le serveur et sélectionnez Créer une base de données. Entrez le nom de la nouvelle base de données et le jeu de caractères spécifié et la collation. Connectez-vous à la nouvelle base de données et créez le tableau dans le navigateur d'objet. Cliquez avec le bouton droit sur le tableau et sélectionnez Insérer des données pour insérer les données.

La copie d'une table dans MySQL nécessite la création de nouvelles tables, l'insertion de données, la définition de clés étrangères, la copie des index, les déclencheurs, les procédures stockées et les fonctions. Les étapes spécifiques incluent: la création d'une nouvelle table avec la même structure. Insérez les données de la table d'origine dans une nouvelle table. Définissez la même contrainte de clé étrangère (si le tableau d'origine en a un). Créer le même index. Créez le même déclencheur (si le tableau d'origine en a un). Créez la même procédure ou fonction stockée (si la table d'origine est utilisée).

NAVICAT pour MARIADB ne peut pas afficher directement le mot de passe de la base de données car le mot de passe est stocké sous forme cryptée. Pour garantir la sécurité de la base de données, il existe trois façons de réinitialiser votre mot de passe: réinitialisez votre mot de passe via Navicat et définissez un mot de passe complexe. Affichez le fichier de configuration (non recommandé, haut risque). Utilisez des outils de ligne de commande système (non recommandés, vous devez être compétent dans les outils de ligne de commande).

Affichez la base de données MySQL avec la commande suivante: Connectez-vous au serveur: MySQL -U Username -P mot de passe Exécuter les bases de données Afficher les bases de données; Commande pour obtenir toutes les bases de données existantes Sélectionnez la base de données: utilisez le nom de la base de données; Tableau de vue: afficher des tables; Afficher la structure de la table: décrire le nom du tableau; Afficher les données: sélectionnez * dans le nom du tableau;
