橘子味的心
标题:SQL LEN() 函数

SQL 中的 LEN() 函数返回文本字段中值的长度

SELECT LEN( column_name ) FROM table_name;

LEN() 返回的是数据库服务器编码下的字符串长度,如果数据库服务器的编码是 UTF-8,那么 '中国' 将返回 6

不过 MySQL 中没有 LEN() 函数,取而代之的是 LENGTH() 函数,但用法都一样

SELECT LENGTH( column_name ) FROM table_name;

注意

一般情况下我们不推荐使用这个函数,因为应用的瓶颈一般在数据库,这两个语句显然会降低数据库的并发能力

范例

LEN() 可以直接返回字符串的长度,比如下面这条语句

 SELECT LENGTH('www.twle.cn 基础教程');

运行结果如下

mysql> SELECT LENGTH('www.twle.cn 基础教程');
+------------------------------------+
| LENGTH('www.twle.cn 基础教程')     |
+------------------------------------+
|                                 24 |
+------------------------------------+

演示数据

先在 MySQL 数据库运行下面的语句创建测试数据

CREATE DATABASE IF NOT EXISTS twle default character set utf8mb4 collate utf8mb4_unicode_ci;

USE twle;

DROP TABLE IF EXISTS `lession`;

CREATE TABLE `lession` (
    id int(11) NOT NULL PRIMARY KEY AUTO_INCREMENT,
    name varchar(32) default '',
    views int(11) NOT NULL default '0',
    created_at DATETIME
);

INSERT INTO lession(id,name,views,created_at) VALUES
(1, 'Python 基础教程',981,'2017-04-18 13:52:03'),
(2, 'Scala 基础教程',73,'2017-04-18 16:03:32'),
(3, 'Ruby 基础教程',199,'2017-05-01 06:16:14');

使用 SELECT * FROM lession; 运行结果如下

+----+---------------------+-------+--------------------+
| id | name               | views | created_at          |
+----+---------------------+-------+--------------------+
|  1 | Python 基础教程     |   981 | 2017-04-18 13:52:03 |
|  2 | Scala 基础教程      |    73 | 2017-04-18 16:03:32 |
|  3 | Ruby 基础教程       |   199 | 2017-05-01 06:16:14 |
+----+---------------------+-------+--------------------+

总共有 3 条记录

SQL LEN() 范例

我们可以使用下面的语句返回 name 列中的长度

SELECT name, LENGTH(name) FROM lession;

运行结果输出如下

mysql> SELECT name, LENGTH(name) FROM lession;
+---------------------+--------------+
| name                | LENGTH(name) |
+---------------------+--------------+
| Python 基础教程     |           19 |
| Scala 基础教程      |           18 |
| Ruby 基础教程       |           17 |
+---------------------+--------------+

目录

分类