博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
5.14 数据库函数,流程控制
阅读量:6800 次
发布时间:2019-06-26

本文共 6229 字,大约阅读时间需要 20 分钟。

函数

内置函数

CHAR_LENGTH(str)        返回值为字符串str 的长度,长度的单位为字符。一个多字节字符算作一个单字符。        对于一个包含五个二字节字符集, LENGTH()返回值为 10, 而CHAR_LENGTH()的返回值为5。    CONCAT(str1,str2,...)        字符串拼接        如有任何一个参数为NULL ,则返回值为 NULL。    CONCAT_WS(separator,str1,str2,...)        字符串拼接(自定义连接符)        CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。    CONV(N,from_base,to_base)        进制转换        例如:            SELECT CONV('a',16,2); 表示将 a 由16进制转换为2进制字符串表示    FORMAT(X,D)        将数字X 的格式写为'#,###,###.##',以四舍五入的方式保留小数点后 D 位, 并将结果以字符串的形式返回。若  D 为 0, 则返回结果不带有小数点,或不含小数部分。        例如:            SELECT FORMAT(12332.1,4); 结果为: '12,332.1000'    INSERT(str,pos,len,newstr)        在str的指定位置插入字符串            pos:要替换位置其实位置            len:替换的长度            newstr:新字符串        特别的:            如果pos超过原字符串长度,则返回原字符串            如果len超过原字符串长度,则由新字符串完全替换    INSTR(str,substr)        返回字符串 str 中子字符串的第一个出现位置。    LEFT(str,len)        返回字符串str 从开始的len位置的子序列字符。    LOWER(str)        变小写    UPPER(str)        变大写    LTRIM(str)        返回字符串 str ,其引导空格字符被删除。    RTRIM(str)        返回字符串 str ,结尾空格字符被删去。    SUBSTRING(str,pos,len)        获取字符串子序列    LOCATE(substr,str,pos)        获取子序列索引位置    REPEAT(str,count)        返回一个由重复的字符串str 组成的字符串,字符串str的数目等于count 。        若 count <= 0,则返回一个空字符串。        若str 或 count 为 NULL,则返回 NULL 。    REPLACE(str,from_str,to_str)        返回字符串str 以及所有被字符串to_str替代的字符串from_str 。    REVERSE(str)        返回字符串 str ,顺序和字符顺序相反。    RIGHT(str,len)        从字符串str 开始,返回从后边开始len个字符组成的子序列    SPACE(N)        返回一个由N空格组成的字符串。    SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)        不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式为标准 SQL 语法。也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。在以下格式的函数中可以对pos 使用一个负值。        mysql> SELECT SUBSTRING('Quadratically',5);            -> 'ratically'        mysql> SELECT SUBSTRING('foobarbar' FROM 4);            -> 'barbar'        mysql> SELECT SUBSTRING('Quadratically',5,6);            -> 'ratica'        mysql> SELECT SUBSTRING('Sakila', -3);            -> 'ila'        mysql> SELECT SUBSTRING('Sakila', -5, 3);            -> 'aki'        mysql> SELECT SUBSTRING('Sakila' FROM -4 FOR 2);            -> 'ki'    TRIM([{BOTH | LEADING | TRAILING} [remstr] FROM] str) TRIM(remstr FROM] str)        返回字符串 str , 其中所有remstr 前缀和/或后缀都已被删除。若分类符BOTH、LEADIN或TRAILING中没有一个是给定的,则假设为BOTH 。 remstr 为可选项,在未指定情况下,可删除空格。        mysql> SELECT TRIM('  bar   ');                -> 'bar'        mysql> SELECT TRIM(LEADING 'x' FROM 'xxxbarxxx');                -> 'barxxx'        mysql> SELECT TRIM(BOTH 'x' FROM 'xxxbarxxx');                -> 'bar'        mysql> SELECT TRIM(TRAILING 'xyz' FROM 'barxxyz');                -> 'barx'
内置函数

  更多函数 ,

自定义函数

#!!!注意!!!#函数中不要写sql语句(否则会报错),函数仅仅只是一个功能,是一个在sql中被应用的功能#若要想在begin...end...中写sql,请用存储过程
delimiter //create function f1(    i1 int,    i2 int)returns intBEGIN    declare num int;  #声明    set num = i1 + i2;    return(num);END //delimiter ;
delimiter //create function f5(    i int)returns intbegin    declare res int default 0;    if i = 10 then        set res=100;    elseif i = 20 then        set res=200;    elseif i = 30 then        set res=300;    else        set res=400;    end if;    return res;end //delimiter ;

 删除函数

drop function func_name;

执行函数

# 获取返回值select UPPER('egon') into @res;SELECT @res;select f1(1,2) into @res;select @res# 在查询中使用 select f1(11,nid) ,name from tb2;

 DATE_FORMAT 使用

#1 基本使用mysql> SELECT DATE_FORMAT('2009-10-04 22:23:00', '%W %M %Y');        -> 'Sunday October 2009'mysql> SELECT DATE_FORMAT('2007-10-04 22:23:00', '%H:%i:%s');        -> '22:23:00'mysql> SELECT DATE_FORMAT('1900-10-04 22:23:00',    ->                 '%D %y %a %d %m %b %j');        -> '4th 00 Thu 04 10 Oct 277'mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00',    ->                 '%H %k %I %r %T %S %w');        -> '22 22 10 10:23:00 PM 22:23:00 00 6'mysql> SELECT DATE_FORMAT('1999-01-01', '%X %V');        -> '1998 52'mysql> SELECT DATE_FORMAT('2006-06-00', '%d');        -> '00'#2 准备表和记录CREATE TABLE blog (    id INT PRIMARY KEY auto_increment,    NAME CHAR (32),    sub_time datetime);INSERT INTO blog (NAME, sub_time)VALUES    ('第1篇','2015-03-01 11:31:21'),    ('第2篇','2015-03-11 16:31:21'),    ('第3篇','2016-07-01 10:21:31'),    ('第4篇','2016-07-22 09:23:21'),    ('第5篇','2016-07-23 10:11:11'),    ('第6篇','2016-07-25 11:21:31'),    ('第7篇','2017-03-01 15:33:21'),    ('第8篇','2017-03-01 17:32:21'),    ('第9篇','2017-03-01 18:31:21');#3. 提取sub_time字段的值,按照格式后的结果即"年月"来分组SELECT DATE_FORMAT(sub_time,'%Y-%m'),COUNT(1) FROM blog GROUP BY DATE_FORMAT(sub_time,'%Y-%m');#结果+-------------------------------+----------+| DATE_FORMAT(sub_time,'%Y-%m') | COUNT(1) |+-------------------------------+----------+| 2015-03                       |        2 || 2016-07                       |        4 || 2017-03                       |        3 |+-------------------------------+----------+rows in set (0.00 sec) DATE_FORMAT需要掌握

流程控制

条件语句

delimiter //CREATE PROCEDURE proc_if ()BEGIN        declare i int default 0;    if i = 1 THEN        SELECT 1;    ELSEIF i = 2 THEN        SELECT 2;    ELSE        SELECT 7;    END IF;END //delimiter ;
#函数中不要写sql语句,它仅仅只是一个功能,是一个在sql中被应用的功能#若要想在begin...end...中写sql,请用存储过程delimiter //create function f5(    i int)returns intbegin    declare res int default 0;    if i = 10 then        set res=100;    elseif i = 20 then        set res=200;    elseif i = 30 then        set res=300;    else        set res=400;    end if;    return res;end //delimiter ;

循环语句

while

delimiter //CREATE PROCEDURE proc_while ()BEGIN    DECLARE num INT ;    SET num = 0 ;    WHILE num < 10 DO        SELECT            num ;        SET num = num + 1 ;    END WHILE ;END //delimiter ;

repeat

delimiter //CREATE PROCEDURE proc_repeat ()BEGIN    DECLARE i INT ;    SET i = 0 ;    repeat        select i;        set i = i + 1;        until i >= 5    end repeat;END //delimiter ;

loop

BEGIN        declare i int default 0;    loop_label: loop                set i=i+1;        if i<8 then            iterate loop_label;        end if;        if i>=10 then            leave loop_label;        end if;        select i;    end loop loop_label;END

 

转载于:https://www.cnblogs.com/shijieli/p/10344668.html

你可能感兴趣的文章
Oracle 字符串处理函数
查看>>
中国银行涉嫌洗黑钱却另有隐情?
查看>>
排序问题分析
查看>>
【无私分享:从入门到精通ASP.NET MVC】从0开始,一起搭框架、做项目(9) 角色管理,分配权限...
查看>>
android bitmap 描边,Android 绘图之Canvas相关API使用
查看>>
爬虫采集-基于webkit核心的客户端Ghost.py [爬虫实例]
查看>>
学霸装学渣
查看>>
Microsoft Dynamics CRM 2015 完全安装好以后 完全备份
查看>>
git 在windows下的应用(一) - 本地仓库代码管理
查看>>
符合通用准则(common criteria compliance)
查看>>
APP-V5.0的Sequencer过程
查看>>
IBM X3650 M3服务器上RAID配置实战
查看>>
Objective-C中的@class,SEL和IMP等灵活机制
查看>>
2030中国足球称霸世界
查看>>
工信部:《关于加强电信和互联网行业网络安全工作的指导意见》
查看>>
开源可实现迁移
查看>>
融合式架构Nutanix深入分析一
查看>>
RHEL6.3下配置简单Apache https
查看>>
利用Cocos2dx-3.0新物理特性模拟弹珠迷宫
查看>>
Office 365系列之三:Office365初体验
查看>>