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 | +---------------------+--------------+