PS:终于看完了字符串函数,心都快碎了...涉及的函数真是太多了...感觉这里的字符串函数和JAVA里的基本都差不多了...基本上算是掌握了,但是想全记住那是不太可能的。。。    

学习内容:

字符串函数的掌握和应用..

ASCii(str)

返回字符串的最左边的ascii码值..如果str为NULL,那么返回NULL...如果字符串为0,那么返回也为0...

mysql>select ascii('');
mysql>select ascii('dx');

ORD(str)函数

如果字符串最左边的字符为多字节字符,那么返回的函数值按照这个公式进行计算...:((first byte ASCII code)*256+(second byte ASCII code))[*256+third byte ASCII code...]。如果最左边的字符不是一个多字节字符,返回值与 ASCII() 函数相同:

mysql> SELECT ORD('');
-> 50
mysql>SELECT ORD('我');
->52946

那么何为多字节的字符呢?最简单的例子就属于汉字了...比如说一个字符串为“我hello”...那么ORD函数会将第一个多字节字符拆分成两个16进制表示的字节。。"我"字可以被拆分成两个字符,并且每个字符使用16进制数字开进行表示为CE D2,那么返回的值就是(12*16+14)*256+(13*16+2)=52946..

CONV(N,from_base,to_base)函数

将一个数字N,从from_base转换为to_base,返回值为字符串..

mysql> SELECT CONV("a",16,2);
-> ''
mysql> SELECT CONV("6E",18,8);
-> ''

BIN(N),OCT(N),HEX(N_or_S)函数..其实就是进制转换...估计大家也不陌生

mysql> SELECT BIN(12);
-> ''
mysql> SELECT OCT(12);
-> ''
mysql> SELECT HEX(255);
-> 'FF'
mysql> SELECT HEX("abc");
-> 616263

CONCAT(str,str1,str2......)字符串连接函数,如果一个值为NULL,那么返回值也为NULL。。

CONCAT_WS(separator,str,str1...)属于上述函数的一种特殊的形式..就是在连接的过程中,在每个字符串之间插入一个标示符..

mysql> SELECT CONCAT('My', 'S', 'QL');
-> 'MySQL'
mysql> SELECT CONCAT_WS(",","First name","Second name","Last Name");
-> 'First name,Second name,Last Name'

Length(str),OCTET_Length(str),CHAR_Length(str),CHARACTER_Length(str)...四个函数等价,返回字符串的字节长度..字符串还有比特长度,比特长度就是这个函数所得到的具体值*8...

mysql> SELECT LENGTH('text');
-> 4

Locate(substr,str),Position(substr In str),返回字串substr在str中第一次出现的位置...Instr(str,substr)变量是反的,不过作用是相同的。。

Locate(substr,str,pos)指定pos位置,查找pos位置以后字串在str第一次出现的位置..

注意:这些函数对于多字节的字符是安全的..mysql的字符串第一个位置是从1开始的..而不是从0开始的..

mysql> SELECT LOCATE('bar', 'foobarbar');
-> 4
mysql> SELECT LOCATE('bar', 'foobarbar',5);
-> 7
mysql> SELECT INSTR('xbar', 'foobar');
-> 0

Substring(str,pos,len),Substring(str from pos for len),mid(str,pos,len)..返回指定pos位置的len长度的字符子串...

Substring(str,pos),Substring(str from pos)。。返回一个从pos位置起的一个字符子串...

mysql> SELECT SUBSTRING('Quadratically',5,6);
-> 'ratica'
mysql> SELECT SUBSTRING('Quadratically',5);
-> 'ratically'

Replace(str,from_str,to_str)字符串frmo_str部分将被to_str所替代..

Reverse(str)字符串反转...

Insert(str,pos,len,newstr)...在pos位置处后面的len长度的字符串将被newstr替代..这些函数对于多字节字符是安全的...

mysql> SELECT REPLACE('www.mysql.com', 'w', 'Ww');
-> 'WwWwWw.mysql.com'
mysql> SELECT REVERSE('abc');
-> 'cba'
mysql> SELECT INSERT('Quadratic', 3, 4, 'What');
-> 'QuWhattic'

Export_set(bits,on,off,[sepatator,[number_of_bits]])不太确定到底能不能用得上,感觉上还是比较重要的...

返回一个字符串,对于在 'bits' 中的每个比特字位,你将得到一个 'on' 字符,而如果比特字位是一个清零比特位(reset bit)你将得到一个 'off' 字符串。每个字符串均被“分隔符”(缺省为“,”)分隔,并且只有 'number_of_bits'(缺省为 64) 个 'bits' 被使用:

mysql> SELECT EXPORT_SET(5,'Y','N',',',4)
-> Y,N,Y,N 一些例子,方便大家去理解... mysql> select EXPORT_SET(1,'','','',5);
-> 10000
# 最左边第一位为 2 的 0 次幂 mysql> select EXPORT_SET(2,'','','',5);
-> 01000
# 最左边第一位为 2 的 0 次幂,第二位为 2 的 1 次幂 mysql> select EXPORT_SET(4,'','','',5);
-> 00100
# 最左边第一位为 2 的 0 次幂,第二位为 2 的 1 次幂,第三位为 2 的 2 次幂 mysql> select EXPORT_SET(15,'','','',5);
-> 11110
# 最左边第一位为 2 的 1 次幂,第四位为 2 的 3 次幂 mysql> select EXPORT_SET(16,'','','',5);
-> 00001
# 最左边第一位为 2 的 1 次幂,第五位为 2 的 4 次幂

Lcase(str)<==>Lower(str),Ucase(str)<==>Upper(str)字符串大小写转换..

Load_file("路径名称")。。。读入文件,将文件中的内容更新到数据库当中...注意:这个文件必须在服务器上,还要有完整的路径名称..如果文件不存在,返回NULL...

mysql> UPDATE tbl_name
SET blob_column=LOAD_FILE("/tmp/picture")
WHERE id=1;

expr REGEXP pat

expr Like pat

依照模式 pat 对字符串表达式 expr 执行一个模式比较。模式可以是一个扩展的正则表达式。Returns 如果表达式 expr 匹配 pat,返回 1,否则返回 0RLIKEREGEXP 的同义词,它提供了与 mSQL 的兼容。注意:MySQL 在字符串中使用的是 C 的转义句法(例如“\n”),所以在 REGEXP 字符串中使用的任何一个“\”必须被双写。在 MySQL 3.23.4 中,REGEXP 对于正常的(不是二进制)字符串是忽略大小写的:

mysql> SELECT 'Monty!' REGEXP 'm%y%%';
-> 0
mysql> SELECT 'Monty!' REGEXP '.*';
-> 1
mysql> SELECT 'new*\n*line' REGEXP 'new\\*.\\*line';
-> 1
mysql> SELECT "a" REGEXP "A", "a" REGEXP BINARY "A";
-> 1 0
mysql> SELECT "a" REGEXP "^[a-d]";
-> 1 当决定一个字符的类型时,REGEXP 和 RLIKE 使用当前使用的字符集(缺省为 ISO-8859-1 Latin1)。

strcmp(str,str1)字符串比较函数...

mysql> SELECT STRCMP('text', 'text2');
-> -1
mysql> SELECT STRCMP('text2', 'text');
-> 1
mysql> SELECT STRCMP('text', 'text');
-> 0

Binary 正常情况下,字符串比较的时候是忽略大小写进行比较的..如果想强制要求大小写...那么使用Binary进行强制要求...

mysql> SELECT "a" = "A";
-> 1
mysql> SELECT BINARY "a" = "A";
-> 0

还有很多的字符串函数并没有提到,感觉用不太上,例举了一些比较重要的字符串函数...希望对自己以后有帮助。。。

Mysql学习笔记(四)字符串函数的更多相关文章

  1. MySql学习笔记四

    MySql学习笔记四 5.3.数据类型 数值型 整型 小数 定点数 浮点数 字符型 较短的文本:char, varchar 较长的文本:text, blob(较长的二进制数据) 日期型 原则:所选择类 ...

  2. [学习笔记] Oracle字符串函数、日期函数、数值函数、转换函数、聚合函数

    函数 单行函数:对一行数据进行操作的函数,如字符串函数.数值函数.转换函数.日期函数等. 聚合函数:同时对多行数据进行操作,如求和函数等. 字符串函数 函数 说明 ASCII(X) 求字符X的ASCI ...

  3. Python学习笔记(四)Python函数的参数

    Python的函数除了正常使用的必选参数外,还可以使用默认参数.可变参数和关键字参数. 默认参数 基本使用 默认参数就是可以给特定的参数设置一个默认值,调用函数时,有默认值得参数可以不进行赋值,如: ...

  4. MySQL学习笔记(四)—存储过程

    一.概述      存储过程是数据库定义的一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句.存储过程可以避免开发人员重复的编写相同的SQL语句,而且存储过程是在MySq ...

  5. MySQL学习笔记:字符串前后补全0

    遇到一个需求:不足6位的需要自动补全6位,使用函数LPAD()和RPAD()补全. LPAD(str, len, padstr) 用字符串padstr对str进行左边填充补全直至它的长度达到len个字 ...

  6. mysql学习笔记—常用sql函数

    SQL 拥有很多可用于计数和计算的内建函数. SQL Aggregate 函数 SQL Aggregate 函数计算从列中取得的值,返回一个单一的值. 有用的 Aggregate 函数: AVG() ...

  7. MySQL学习笔记四:字符集

    1.字符集就是字符和其编码的集合,查看数据库支持的字符集 show character set 2.查看服务端启动时默认的字符集 mysql> show variables like 'char ...

  8. MySQL学习笔记(四):存储引擎的选择

    一:几种常用存储引擎汇总表 二:如何选择 一句话:除非需要InnoDB 不具备的特性,并且没有其他办法替代,否则都应该优先考虑InnoDB:或者,不需要InnoDB的特性,并且其他的引擎更加合适当前情 ...

  9. mysql学习笔记四 —— AB复制

    要点:ab复制 mysql集群架构流程: ABB(主从复制)-->MHA(实现mysql高可用.读写分离.脚本控制vip飘逸)-->haproxy(对slave集群实现分发,负载均衡)-- ...

  10. scala 学习笔记四 匿名函数

    1.介绍 Scala 中定义匿名函数的语法很简单,箭头左边是参数列表,右边是函数体. 使用匿名函数后,我们的代码变得更简洁了. 下面的表达式就定义了一个接受一个Int类型输入参数的匿名函数: var ...

随机推荐

  1. ES5 数组方法reduce

    reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始合并,最终为一个值. 参数 callback 执行数组中每个值的函数,包含四个参数 previou ...

  2. nginx location 的配置

    一.基本语法:location [=|~|~*|^~] /uri/ { … } 二.分类: 1.基本location:以“ = ”或“ ^~ ”为前缀或者没有任何前缀的 /uri/ 2.正则locat ...

  3. Tomcat8配置数据库连接池

    1.所有的tomcat项目共用一个连接池配置 1.1 修改conf->context.xml文件,在Context节点下配置 <Resource name="jdbc/myDat ...

  4. IOS , plist 配置项说明

    本文转载至 http://blog.csdn.net/fengsh998/article/details/8307424 Key:Application can be killed immediate ...

  5. C#如何更好地理解引用类型和值类型

    说道值类型和引用类型,在C#中,官方的说法就是: 值类型直接指向数据:一般包括C#自带的所有数字类型,字符类型,bool类型,当然还有自定义的结构类型和枚举类型 而引用类型则是指向数据存储的地址.一般 ...

  6. floor相关

    select floor(@f*0.22) -- 直接可显示结果 create table demo( id ,), id1 int ) select * from demo insert into ...

  7. ubuntu tomcat 部署java web

    1,安装jdk apt-get install openjdk-7-jdk 2,下载tomcat.解压到对应的文件夹 3,将xxx.war放入到 tomcat下的  webapp目录下(此目录下不要有 ...

  8. 解决URL路径包含+等特殊符号,编码也无效的办法

    <?xml version="1.0" encoding="UTF-8"?><configuration>      <syste ...

  9. [论文笔记] Methodologies for Data Quality Assessment and Improvement (ACM Comput.Surv, 2009) (1)

    Carlo Batini, Cinzia Cappiello, Chiara Francalanci, and Andrea Maurino. 2009. Methodologies for data ...

  10. Could not find the Visual SourceSafe Internet Web Service connection information for the specified database Would you like to launch the Visual sourceSafe connection wizard?

    今天同事遇到个奇怪问题,以前也遇到过,不过重新绑定一下就OK了,不知道为什么今天不行了. 错误提示:===============================================Cou ...