MySQL语句 MySQL SHOW DATABASES 显示数据库MySQL SHOW SCHEMAS 显示数据库语句MySQL CREATE DATABASE 创建数据库语句MySQL CREATE SCHEMA 创建数据库语句MySQL SHOW CREATE DATABASE 显示创建数据库的语句MySQL SHOW CREATE SCHEMA 显示创建数据库的语句MySQL ALTER DATABASE 修改数据库语句MySQL ALTER SCHEMA 修改数据库语句MySQL DROP DATABASE删除数据库MySQL DROP SCHEMA 删除数据库MySQL USE 选择数据库语句MySQL CREATE TEMPORARY TABLE 创建临时表语句 MySQL CREATE TABLE 创建数据表语句MySQL DROP TEMPORARY TABLE 删除临时表语句MySQL DROP TABLE 删除数据表语句MySQL SELECT 查询语句MySQL INSERT INTO 增加数据语句MySQL UPDATE 更新语句MySQL ALTER TABLE 修改数据表语句MySQL SHOW TABLES 显示数据表语句MySQL DESCRIBE/DESC 查看数据表语句MySQL SHOW CREATE TABLE 显示创建表语句MySQL DELETE 删除表数据语句MySQL WHERE 条件语句MySQL TRUNCATE 清空表语句MySQL LIKE 模糊匹配语句MySQL NOT LIKE 模式匹配外语句MySQL DISTINCT 去重语句MySQL AS 别名语句MySQL INSERT IGNORE INTO 忽略重复数据插入语句MySQL GROUP BY 分组语句MySQL HAVING 包含语句MySQL LIMIT限制查询数量 语句MySQL ORDER BY 排序语句MySQL BETWEEN AND 筛选范围内数据语句MySQL NOT BETWEEN AND 筛选不在范围数据语句MySQL IS NULL 查询是否为NULL值语句MySQL IS NOT NULL 查询不为NULL值语句MySQL IN 查询某个范围内的数据语句MySQL NOT IN 查询某个不在范围内的数据语句MySQL SELECTI...INTO OUTFILE将查询结果输出到外部文件语句MySQL LOAD DATA大量数据快速导入数据库语句MySQL UNION 合并两个或多个SELECT语句MySQL数据类型 MySQL tinyint、smallint、mediumint、int、bigint整数数据类型(精确值)MySQL decimal、numeric、double、float、real小数数据类型(精确、近似值)MySQL date、time、year、timestamp、datetime日期时间数据类型MySQL char、varchar、text、enum、set字符串类型MySQL bit、binary、varbinary、tinyblob、blob、mediumblob、longblob二进制数据类型MySQL空间数据类型MySQL函数 MySQL COUNT 统计函数MySQL ANY_VALUE函数 禁止 ONLY_FULL_GROUP_BY 值拒绝MySQL CASE 多分支函数MySQL LENGTH 返回字节数函数MySQL CHARACTER_LENGTH 返回字符数函数MySQL CHAR_LENGTH 返回字符数函数MySQL SUBSTRING提取字符串函数MySQL CONCAT 合拼字符串函数MySQL INSERT替换字符串函数MySQL LOWER 字符串转为小写 函数MySQL UPPER 字符串转为大写 函数MySQL LEFT 提取左侧字符 函数MySQL RIGHT 提取右侧字符 函数MySQL TRIM 删除头尾空格或指定字符 函数MySQL REPLACE 替换字符串函数MySQL REVERSE 字符串反转函数MySQL ABS求绝对值函数MySQL FIND_IN_SET 查逗号分隔特定值函数 MySQL ASCII最左边字符的数字值函数MySQL BIN将整数值转二进制字符串函数MySQL BIT_LENGTH返二进制字符串长度函数MySQL CONCAT_WS用分隔符连接字符串函数MySQL INTERVAL 返N值在区间段索引位置 函数MySQL ELT 指定位置提取子字符串函数MySQL IFNULL 处理NULL值函数MySQL EXPORT_SET二进制位生成拼接字符串函数MySQL FIELD 包含特定值的位置函数MySQL FORMAT 返回带有格式的数字函数MySQL TO_BASE64 字符串转base-64编码函数MySQL FROM_BASE64 将base-64编码解码函数MySQL AES_ENCRYPT 使用密钥进行加密函数MySQL AES_DECRYPT使用密钥解密函数MySQL HEX字符串转十六进制函数MySQL UNHEX 十六进制字符串转二进制数据函数MySQL INSTR 返回子字符串第一次出现的索引函数MySQL REGEXP 正则表达式函数MySQL NOT REGEXP不匹配正则表达式函数MySQL LCASE用于转换字符串为小写函数MySQL LOAD_FILE 加载文件到数据库函数MySQL LOCATE 搜索字符串第一次出现的位置函数MySQL LPAD左侧添加指定长度字符函数MySQL LTRIM删除字符串左侧空格的函数MySQL MAKE_SET 创建集合函数

MySQL ELT 指定位置提取子字符串函数

MySQL数据库中的ELT函数是一个用于字符串处理的函数,它可以根据指定的位置从字符串中提取子字符串。

函数的语法

ELT(pos, str1, str2, ..., strN)

其中,pos是指要提取的子字符串的位置,str1, str2, ..., strN是要提取的字符串列表。

注意pos从1开始,如果pos=1,则返回str1,如果pos=2,则返回str2,依次类推。如果pos小于1或大于参数个数,返回NULL。

简单示例

mysql> SELECT ELT(1, 'Aa', 'Bb', 'Cc', 'Dd');
+--------------------------------+
| ELT(1, 'Aa', 'Bb', 'Cc', 'Dd') |
+--------------------------------+
| Aa                             |
+--------------------------------+

mysql> SELECT ELT(4, 'Aa', 'Bb', 'Cc', 'Dd');
+--------------------------------+
| ELT(4, 'Aa', 'Bb', 'Cc', 'Dd') |
+--------------------------------+
| Dd                             |
+--------------------------------+

案例:

可以利用INTERVAL做区间判断,比如查询分数区间,转换状态等;

获取案例新建表格和插入数据语句

这是详细信息得内容。

-- 创建数据表  
CREATE TABLE student (  
  id INT AUTO_INCREMENT PRIMARY KEY,  
  name VARCHAR(50),  
  score INT,  
  sex VARCHAR(10)  
);  
  
-- 插入数据  
INSERT INTO student (name, score, sex) VALUES ('张三', 80, '1');  
INSERT INTO student (name, score, sex) VALUES ('李四', 90, '0');  
INSERT INTO student (name, score, sex) VALUES ('王五', 70, NULL); 
INSERT INTO student (name, score, sex) VALUES ('赵六', 40, '2');  
INSERT INTO student (name, score, sex) VALUES ('陈七', 60, '');


原始数据:

mysql> select * from student;
+----+--------+-------+------+
| id | name   | score | sex  |
+----+--------+-------+------+
|  1 | 张三   |    80 | 1    |
|  2 | 李四   |    90 | 0    |
|  3 | 王五   |    70 | NULL |
|  4 | 赵六   |    40 | 2    |
|  5 | 陈七   |    60 |      |
+----+--------+-------+------+

转换状态

我们在项目中还有一个地方也会经常用到,比如需要在查询时候,把存在数据表中的状态值(一般是数字)转换成对应的中文描述值。

下面我们将sex字段1转换为男,2转换为女

mysql> SELECT name,sex,ELT(sex,'男','女')as sex_text FROM student;

+--------+------+----------+
| name   | sex  | sex_text |
+--------+------+----------+
| 张三   | 1    | 男       |
| 李四   | 0    | NULL     |
| 王五   | NULL | NULL     |
| 赵六   | 2    | 女       |
| 陈七   |      | NULL     |
+--------+------+----------+

要注意得的是有种情况是在实际项目的时候有数据表和字段的类型已经被定义好了,比如说0为“未知性别”ELT则是从1开始的,没有办法处理,这时候就可以结合其他的函数一起使用。和INTERVAL函数一起使用就可以解决这个问题。

mysql> SELECT name,sex,ELT(INTERVAL(sex,0,1,2),'未知性别','男','女') as sex_text FROM student;
+--------+------+--------------+
| name   | sex  | sex_text     |
+--------+------+--------------+
| 张三   | 1    | 男           |
| 李四   | 0    | 未知性别     |
| 王五   | NULL | NULL         |
| 赵六   | 2    | 女           |
| 陈七   |      | 未知性别     |
+--------+------+--------------+
5 rows in set (0.00 sec)

 由于sex可能为null值,返回的索引值就是-1,在ELT函数中就没有对应值,也会返回null,如果不想出现NULL值可以加上IFNULL函数判断,请看一下语句:

mysql> SELECT name,sex,IFNULL(ELT(INTERVAL(sex,0,1,2),'未知性别','男','女'),'') as sex_text FROM student;
+--------+------+--------------+
| name   | sex  | sex_text     |
+--------+------+--------------+
| 张三   | 1    | 男           |
| 李四   | 0    | 未知性别     |
| 王五   | NULL |              |
| 赵六   | 2    | 女           |
| 陈七   |      | 未知性别     |
+--------+------+--------------+

 查询分数区间

现在统计分数小于60的为不及格的人数,大于等于60小于80的为中等的人数,大于等于80小于100的为优秀,等于100的为满分

sql语句可以这样写:

mysql> SELECT name,score,ELT(INTERVAL(score,0,60,80,100),'不及格','中等','优秀','满分') as score_level FROM student;
+--------+-------+-------------+
| name   | score | score_level |
+--------+-------+-------------+
| 张三   |    80 | 优秀        |
| 李四   |    90 | 优秀        |
| 王五   |    70 | 中等        |
| 赵六   |    40 | 不及格      |
| 陈七   |    60 | 中等        |
+--------+-------+-------------+

注意事项:

在使用ELT函数时,需要注意以下几点: