zoukankan      html  css  js  c++  java
  • mysql函数

      时间函数

    1.时间转字符串
    DATE_FORMAT(日期,格式字符串)
    SELECT DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s');
    
    2.字符串转时间
    STR_TO_DATE(字符串,日志格式)
    SELECT STR_TO_DATE('2019-01-20 16:01:45', '%Y-%m-%d %H:%i:%s');
    
    3.时间转时间戳
    select unix_timestamp(now());
    
    4.字符串转时间戳
    select unix_timestamp('2019-01-20');
    
    5.时间戳转字符串
    select from_unixtime(1451997924,'%Y-%d');
    
    附日期格式如下:
    %M 月名字(January……December) 
    %W 星期名字(Sunday……Saturday) 
    %D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。) 
    %Y 年, 数字, 4 位 
    %y 年, 数字, 2 位 
    %a 缩写的星期名字(Sun……Sat) 
    %d 月份中的天数, 数字(00……31) 
    %e 月份中的天数, 数字(0……31) 
    %m 月, 数字(01……12) 
    %c 月, 数字(1……12) 
    %b 缩写的月份名字(Jan……Dec) 
    %j 一年中的天数(001……366) 
    %H 小时(00……23) 
    %k 小时(0……23) 
    %h 小时(01……12) 
    %I 小时(01……12) 
    %l 小时(1……12) 
    %i 分钟, 数字(00……59) 
    %r 时间,12 小时(hh:mm:ss [AP]M) 
    %T 时间,24 小时(hh:mm:ss) 
    %S 秒(00……59) 
    %s 秒(00……59) 
    %p AM或PM 
    %w 一个星期中的天数(0=Sunday ……6=Saturday ) 
    %U 星期(0……52), 这里星期天是星期的第一天 
    %u 星期(0……52), 这里星期一是星期的第一
    

      数值转字符串函数

     CAST,CONVERT 可以转换的类型是有限制的。这个类型可以是以下值其中的一个:

    • 二进制,同带binary前缀的效果 : BINARY    
    • 字符型,可带参数 : CHAR()     
    • 日期 : DATE     
    • 时间: TIME     
    • 日期时间型 : DATETIME     
    • 浮点数 : DECIMAL      
    • 整数 : SIGNED     
    • 无符号整数 : UNSIGNED 
    SELECT CAST('123' AS SIGNED);
    SELECT CONVERT('123',SIGNED);
    SELECT '123'+0;
    
    
    DECLARE @dt datetime
    --单纯的日期
    SET @dt='1900-1-2'
    SELECT CAST(@dt as binary(8))
    --结果: 0x0000000100000000
      
    --单纯的时间
    SET @dt='00:00:01'
    SELECT CAST(@dt as binary(8))
    --结果: 0x000000000000012C
    

      字符串操作函数

    1、字符串的拼接
    1.1 CONCAT(s1,s2,...)函数
    返回连接参数产生的字符串,一个或多个待拼接的内容,任意一个为NULL则返回值为NULL。
    SELECT CONCAT('现在的时间:',NOW());  -- 输出结果:现在的时间:2019-01-17 11:27:58
    
    1.2 CONCAT_WS(x,s1,s2,...)函数
    返回多个字符串拼接之后的字符串,每个字符串之间有一个x。
    SELECT CONCAT_WS(';','pan_junbiao的博客','KevinPan','pan_junbiao'); -- 输出结果:pan_junbiao的博客;KevinPan;pan_junbiao
    
    2、字符串的截取
    2.1 SUBSTRING(s,n,len)、MID(s,n,len)函数
    两个函数作用相同,从字符串s中返回一个第n个字符开始、长度为len的字符串。
    SELECT SUBSTRING('您好,欢迎访问pan_junbiao的博客',8,14);  -- 输出结果:pan_junbiao的博客
    SELECT MID('您好,欢迎访问pan_junbiao的博客',8,14);        -- 输出结果:pan_junbiao的博客
    
    2.2 LEFT(s,n)、RIGHT(s,n)函数
    前者返回字符串s从最左边开始的n个字符,后者返回字符串s从最右边开始的n个字符。
    SELECT LEFT('您好,欢迎访问pan_junbiao的博客',7);   -- 输出结果:您好,欢迎访问
    SELECT RIGHT('您好,欢迎访问pan_junbiao的博客',14); -- 输出结果:pan_junbiao的博客
    
    3、字符串的替换
    3.1 INSERT(s1,x,len,s2)函数
    返回字符串s1,其子字符串起始于位置x,被字符串s2取代len个字符。
    SELECT INSERT('您好,欢迎访问阿标的博客',8,2,'pan_junbiao');  -- 输出结果:您好,欢迎访问pan_junbiao的博客
    
    3.2 REPLACE(s,s1,s2)函数
    返回一个字符串,用字符串s2替代字符串s中所有的字符串s1。
    SELECT REPLACE('您好,欢迎访问阿标的博客','阿标','pan_junbiao'); -- 输出结果:您好,欢迎访问pan_junbiao的博客
    
    4、字符串的查询位置
    4.1 LOCATE(str1,str)、POSITION(str1 IN str)、INSTR(str,str1)函数
    三个函数作用相同,返回子字符串str1在字符串str中的开始位置(从第几个字符开始)。
    SELECT LOCATE('pan_junbiao','您好,欢迎访问pan_junbiao的博客');       -- 输出结果:8
    SELECT POSITION('pan_junbiao' IN '您好,欢迎访问pan_junbiao的博客');  -- 输出结果:8
    SELECT INSTR('您好,欢迎访问pan_junbiao的博客','pan_junbiao');        -- 输出结果:8
    
    4.2 FIELD(s,s1,s2,...)函数
    返回第一个与字符串s匹配的字符串的位置。
    SELECT FIELD('pan_junbiao','pan_junbiao的博客','KevinPan','阿标','pan_junbiao');  -- 输出结果:4
    

      

  • 相关阅读:
    SpringMvc 的小dome
    解决Eclipse加载Tomcat报错Could not load the Tomcat server configuration.The configuration may be corrupt or incomplete.
    【转载】理解java三层架构:持久层、业务层、表现层
    Eclipse 报错 org.springframework.context.support.AbstractApplicationContext refresh处理
    Eclipes 报错The ... package is not accessible解决
    Tomcat文件目录及用途
    MyBatis配置文件mybatis-config.xml中的mappers中引入映射文件的几种方式总结
    Mybatis中自动生成主键在mysql和Oracle当中的情况
    mybatis中int类型的判断问题分析
    Cause: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 56; columnNumber: 17
  • 原文地址:https://www.cnblogs.com/iupoint/p/12876435.html
Copyright © 2011-2022 走看看