骚骚的sql

  • id补齐多少位:LPAD( CONCAT( user_id, '' )

  • 用户ID后四位:substring( LPAD( CONCAT( user_id, '' ), 10, '0' ), - 4 )

  • 时间戳后8位:substring( CONCAT( UNIX_TIMESTAMP( create_time ), '' ), 3 )

  • ID后四位+时间戳后8位:CONCAT(用户ID后四位 , 时间戳后8位)

  • 字符串转json并取值:JSON_EXTRACT( cast( buy_price_size AS json ), '$."44"' )

  • 当前日期:select CURRENT_DATE()

  • 当前时间:select CURRENT_TIME()

  • 当前完整时间:select CURRENT_TIMESTAMP()

  • 明天:select CURRENT_TIMESTAMP() + INTERVAL 1 day

  • 明年:select CURRENT_TIMESTAMP() + INTERVAL 1 year

  • 当前时间戳(精确度):REPLACE ( unix_timestamp( CURRENT_TIMESTAMP ( 3 )), '.', '' )。 精确到3位,最多6位3
    SELECT UNIX_TIMESTAMP(NOW(3)) * 1000;

  • 数字转化成字符:CONCAT( 11111, '' )

  • 字符串拼接:CONCAT('a', 'b')

  • 替换字段中的部分内容:replace (field_name,'from_str','to_str')

  • 时间戳转字符串:FROM_UNIXTIME(end_time/1000,'%Y-%m-%d %h:%i:%s')

  • 字符串的数字,怎么写可以用来排序

    •   -- 您可以使用 `CAST()` 函数将字符串转换为数字类型,例如:
        SELECT * FROM my_table ORDER BY CAST(my_column AS UNSIGNED) ASC;
        -- 这将按升序对 `my_column` 中的数字进行排序。如果您的字符串中包含小数,则可以使用 `DECIMAL` 代替 `UNSIGNED`。
      
  • 怎么把字符的数字,按照6位长度以0来补足

    •   -- 您可以使用 `LPAD()` 函数将数字转换为指定长度的字符串,并在左侧使用零进行填充。例如:
        SELECT LPAD(my_column, 6, '0') FROM my_table;
        -- 这将把 `my_column` 中的数字转换为长度为 6 的字符串,并在左侧使用零进行填充。如果 `my_column` 中的数字本身已经大于或等于 6 位数,则不会进行任何更改,仍然保持原样。
      
posted @   pywjh  阅读(93)  评论(0编辑  收藏  举报
编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
回到顶部
点击右上角即可分享
微信分享提示