MySQL实用函数大总结

mysql视频教程栏目介绍实用函数。

MySQL实用函数大总结

相关免费学习推荐:mysql视频教程

MySQL函数大全和函数讲解,管理MYSQL数据一定会用到。
:  mysql的下标是从1开始

ASCII(str)
     返回字符串str的最左面字符的ASCII代码值。如果str是空字符串,返回0。如果str是NULL,返回NULL

mysql> select ASCII('2');    -> 50mysql> select ASCII(2);    -> 50mysql> select ASCII('dx');    -> 100

ORD(str)
      如果字符串str最左面字符是一个多字节字符,通过以格式((first byte ASCII code)256+(second byte ASCII code))[256+third byte ASCII code…]返回字符的ASCII代码值来返回多字节字符代码。如果最左面的字符不是一个多字节字符。返回与ASCII()函数返回的相同值。

mysql> select ORD('2');    -> 50

CONV(N,from_base,to_base)
      在不同的进制之间变换数字。返回数字N的字符串数字,从from_base进制变换为to_base进制,如果任何参数是NULL,返回NULL。参数N解释为一个整数,但是可以指定为一个整数或一个字符串。最小进制是2且最大的进制是36。如果to_base是一个负数,N被认为是一个有符号数,否则,N被当作无符号数。 CONV以64位点精度工作。
即:N是要转换的数据,from_base是原进制,to_base是目标进制。

mysql> select CONV("a",16,2);    -> '1010'mysql> select CONV("6E",18,8);    -> '172'mysql> select CONV(-17,10,-18);    -> '-H'mysql> select CONV(10+"10"+'10'+0xa,10,10);    -> '40'

BIN(N)
      返回二进制值N的一个字符串表示,在此N是一个长整数(BIGINT)数字,这等价于CONV(N,10,2)。如果NNULL,返回NULL

mysql> select BIN(12);    -> '1100'

OCT(N)
      返回八进制值N的一个字符串的表示,在此N是一个长整型数字,这等价于CONV(N,10,8)。如果NNULL,返回“。

mysql> select OCT(12);    -> '14'

HEX(N)
      返回十六进制值N一个字符串的表示,在此N是一个长整型(BIGINT)数字,这等价于CONV(N,10,16)。如果NNULL,返回NULL

mysql> select HEX(255);    -> 'FF'

CHAR(N,...)
      CHAR()将参数解释为整数并且返回由这些整数的ASCII代码字符组成的一个字符串。NULL值被跳过。

mysql> select CHAR(77,121,83,81,'76');    -> 'MySQL'mysql> select CHAR(77,77.3,'77.3');    -> 'MMM'

CONCAT(str1,str2,...)
      返回来自于参数连结的字符串。如果任何参数是NULL,返回NULL。可以有超过2个的参数。一个数字参数被变换为等价的字符串形式。

mysql> select CONCAT('My', 'S', 'QL');    -> 'MySQL'mysql> select CONCAT('My', NULL, 'QL');    -> NULLmysql> select CONCAT(14.3);    -> '14.3'

9.LENGTH(str)OCTET_LENGTH(str)CHAR_LENGTH(str)CHARACTER_LENGTH(str)
      返回字符串str的长度。
注意,对于多字节字符,其CHAR_LENGTH()仅计算一次。

mysql> select LENGTH('text');    -> 4mysql> select LENGTH('简书');    -> 6mysql> select OCTET_LENGTH('text');    -> 4mysql> select OCTET_LENGTH('简书');    -> 6mysql> select CHAR_LENGTH('text');    -> 4mysql> select CHAR_LENGTH('简书');    -> 2mysql> select CHARACTER_LENGTH('text');    -> 4mysql> select CHARACTER_LENGTH('简书');    -> 2

LOCATE(substr,str)POSITION(substr IN str)
      返回子串substr在字符串str第一个出现的位置,如果substr不是在str里面,返回0。

mysql> select LOCATE('bar', 'foobarbar');    -> 4mysql> select LOCATE('xbar', 'foobar');    -> 0

该函数是多字节可靠的。

LOCATE(substr,str,pos)
      返回子串substr在字符串str第一个出现的位置,从位置pos开始。如果substr不是在str里面,返回0。

mysql> select LOCATE('bar', 'foobarbar',5);    -> 7

该函数是多字节可靠的。

INSTR(str,substr)
      返回子串substr在字符串str中的第一个出现的位置。这与有2个参数形式的LOCATE()相同,除了参数被颠倒。

mysql> select INSTR('foobarbar', 'bar');    -> 4mysql> select INSTR('xbar', 'foobar');    -> 0

LPAD(str,len,padstr)
      返回字符串str,左面用字符串padstr填补直到str是len个字符长。

mysql> select LPAD('hi',7,'abc');    -> 'abcabhi'

RPAD(str,len,padstr)
      返回字符串str,右面用字符串padstr填补直到str是len个字符长。

mysql> select RPAD('hi',7,'abc');    -> 'hiabcab'

LEFT(str,len)
      返回字符串str的最左面len个字符。

mysql> select LEFT('foobarbar', 5);    -> 'fooba'

RIGHT(str,len)
      返回字符串str的最右面len个字符。

mysql> select RIGHT('foobarbar', 4);    -> 'rbar'

SUBSTRING(str,pos,len)SUBSTRING(str FROM pos FOR len)MID(str,pos,len)
      从字符串str返回一个len个字符的子串,从位置pos开始。使用FROM的变种形式是ANSI SQL92语法。

mysql> select SUBSTRING('Quadratically',5,6);    -> 'ratica'mysql> select SUBSTRING('helloworld' FROM 2 FOR 5);    -> 'ellow'mysql> select MID('helloworld' FROM 2 FOR 5);    -> 'ellow'

SUBSTR用法同SUBSTRING

BibiGPT-哔哔终结者 BibiGPT-哔哔终结者

B站视频总结器-一键总结 音视频内容

BibiGPT-哔哔终结者 28 查看详情 BibiGPT-哔哔终结者 SUBSTRING_INDEX(str,delim,count)
      返回从字符串str的第count个出现的分隔符delim之后的子串。如果count是正数,返回最后的分隔符到左边(从左边数) 的所有字符。如果count是负数,返回最后的分隔符到右边的所有字符(从右边数)。

mysql> select SUBSTRING_INDEX('www.mysql.com', '.', 2);    -> 'www.mysql'mysql> select SUBSTRING_INDEX('www.mysql.com', '.', -2);    -> 'mysql.com'

LTRIM(str)
      返回删除了其前置空格字符的字符串str。

mysql> select LTRIM('     barbar');    -> 'barbar'

RTRIM(str)
      返回删除了其拖后空格字符的字符串str。

mysql> select RTRIM('barbar   ');    -> 'barbar'

TRIM([remstr FROM] str)TRIM([[BOTH | LEADING | TRAILING] [remstr] FROM] str)
      返回字符串str,其所有remstr前缀或后缀被删除了。如果没有修饰符BOTH、LEADING或TRAILING给出,BOTH被假定。如果remstr没被指定,空格被删除(中间空格不删除)。

 mysql> SELECT TRIM('  bar  bar   ');         -> 'bar  bar' mysql> SELECT TRIM(LEADING 'x' FROM 'xxxbarxxx');   --删除指定的首字符 x         -> 'barxxx' mysql> SELECT TRIM(BOTH 'x' FROM 'xxxbarxxx');      --删除指定的首尾字符 x         -> 'bar' mysql> SELECT TRIM(TRAILING 'xyz' FROM 'barxxyz');  --删除指定的尾字符 x         -> 'barx'

SOUNDEX(str)
      返回str的一个同音字符串。听起来“大致相同”的2个字符串应该有相同的同音字符串。一个“标准”的同音字符串长是4个字符,但是SOUNDEX()函数返回一个任意长的字符串。你可以在结果上使用SUBSTRING()得到一个“标准”的 同音串。所有非数字字母字符在给定的字符串中被忽略。所有在A-Z之外的字符国际字母被当作元音。

mysql> select SOUNDEX('Hello');    -> 'H400'mysql> select SOUNDEX('Quadratically');    -> 'Q36324'

SPACE(N)
      返回由N个空格字符组成的一个字符串。

mysql> select SPACE(6);    -> '     '

REPLACE(str,from_str,to_str)
      返回字符串str,其字符串from_str的所有出现由字符串to_str代替。

mysql> select REPLACE('www.mysql.com', 'w', 'Ww');    -> 'WwWwWw.mysql.com'

REPEAT(str,count)
      返回由重复countTimes次的字符串str组成的一个字符串。如果count <= 0,返回一个空字符串。如果str或count是NULL,返回NULL

mysql> select REPEAT('MySQL', 3);    -> 'MySQLMySQLMySQL'

REVERSE(str)
      返回颠倒字符顺序的字符串str。

mysql> select REVERSE('abc');    -> 'cba'

INSERT(str,pos,len,newstr)
      返回字符串str,在位置pos起始的子串且len个字符长得子串由字符串newstr代替。

mysql> select INSERT('Quadratic', 3, 4, 'What');    -> 'QuWhattic'

ELT(N,str1,str2,str3,...)
      如果N= 1,返回str1,如果N= 2,返回str2,等等。如果N小于1或大于参数个数,返回NULLELT()FIELD()反运算。

mysql> select ELT(1, 'ej', 'Heja', 'hej', 'foo');    -> 'ej'mysql> select ELT(4, 'ej', 'Heja', 'hej', 'foo');    -> 'foo'

FIELD(str,str1,str2,str3,...)
      返回str在str1, str2, str3, …清单的索引。如果str没找到,返回0。FIELD()ELT()反运算。

mysql> select FIELD('ej', 'Hej', 'ej', 'Heja', 'hej', 'foo');    -> 2mysql> select FIELD('fo', 'Hej', 'ej', 'Heja', 'hej', 'foo');    -> 0

FIND_IN_SET(str,strlist)
      如果字符串str在由N子串组成的表strlist之中,返回一个1到N的值。一个字符串表是被“,”分隔的子串组成的一个字符串。如果第一个参数是一个常数字符串并且第二个参数是一种类型为SET的列,FIND_IN_SET()函数被优化而使用位运算!如果str不是在strlist里面或如果strlist是空字符串,返回0。如果任何一个参数是NULL,返回NULL。如果第一个参数包含一个“,”,该函数将工作不正常。

mysql> SELECT FIND_IN_SET('b','a,b,c,d');   -> 2

MAKE_SET(bits,str1,str2,...)
      返回一个集合 (包含由“,”字符分隔的子串组成的一个字符串),由相应的位在bits集合中的的字符串组成。str1对应于位0,str2对应位1,等等。在str1, str2, …中的NULL串不添加到结果中。

mysql> SELECT MAKE_SET(1,'a','b','c');    -> 'a'mysql> SELECT MAKE_SET(1 | 4,'hello','nice','world');    -> 'hello,world'mysql> SELECT MAKE_SET(1 | 4,'hello','nice',NULL,'world');-> 'hello'mysql> SELECT MAKE_SET(0,'a','b','c');    -> ''

说明
bits应将期转为二进制,如,1为,0001,倒过来排序,则为1000,将bits后面的字符串str1,str2等,放置在这个倒过来的二进制排序中,取出值为1对应的字符串,则得到hello.

1|4表示进行或运算,为0001 | 0100,得0101,倒过来排序,为1010,则’hello’,’nice’,’world’得到的是hello word。’hello’,’nice’,NULL,’world’得到的是hello。NULL不取,只有1才取对应字符串.

EXPORT_SET(bits,on,off,[separator,[number_of_bits]])
      返回一个字符串,在这里对于在“bits”中设定每一位,你得到一个“on”字符串,并且对于每个复位(reset)的位,你得到一个“off”字符串。每个字符串用“separator”分隔(缺省“,”),并且只有“bits”的“number_of_bits” (缺省64)位被使用。

mysql> select EXPORT_SET(5,'Y','N',',',4)    -> Y,N,Y,N

LCASE(str)LOWER(str)
      返回字符串str,根据当前字符集映射(缺省是ISO-8859-1 Latin1)把所有的字符改变成小写。该函数对多字节是可靠的。

mysql> select LCASE('QUADRATICALLY');    -> 'quadratically'

UCASE(str)UPPER(str)
      返回字符串str,根据当前字符集映射(缺省是ISO-8859-1 Latin1)把所有的字符改变成大写。该函数对多字节是可靠的。

mysql> select UCASE('Hello');    -> 'HELLO'

LOAD_FILE(file_name)
      读入文件并且作为一个字符串返回文件内容。文件必须在服务器上,你必须指定到文件的完整路径名,而且你必须有file权限。文件必须所有内容都是可读的并且小于max_allowed_packet。如果文件不存在或由于上面原因之一不能被读出,函数返回NULL

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

CONCAT(str1,str2,...)
      将多个字符串连接成一个字符串,返回结果为连接参数产生的字符串。如有任何一个参数为NULL,则返回值为 NULL。或许有一个或多个参数。 如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast, 例如: SELECT CONCAT(CAST(int_col AS CHAR), char_col)

mysql> SELECT CONCAT('My','S','ql');    -> ‘MySQL’mysql> SELECT CONCAT('My', NULL, 'ql');    -> NULLmysql> SELECT CONCAT(14.3);    -> '14.3'

MySQL必要时自动变换数字为字符串,并且反过来也如此:

mysql> SELECT 1+"1";    -> 2mysql> SELECT CONCAT(2,' test');    -> '2 test'

CONCAT_WS(separator,str1,str2,…)
      CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。   第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为NULL,则结果为NULL。函数会忽略任何分隔符参数后的 NULL 值。

mysql>select CONCAT_WS(',','First name','Second name','Last Name');    -> 'First name,Second name,Last Name'mysql> select CONCAT_WS(',','First name',NULL,'Last Name');    -> 'First name,Last Name'

 CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。

以上就是MySQL实用函数大总结的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/354149.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 23:47:20
下一篇 2025年11月5日 23:48:50

相关推荐

  • 前端日志系统设计与实现

    前端日志系统是排查问题、监控体验和优化性能的关键工具,需具备采集、分级、上报、存储与展示能力。首先定义日志级别(debug、info、warn、error、fatal),线上通常只上报warn及以上以控制数据量;结合自动采集(JS错误、Promise异常、资源加载失败、框架错误钩子、性能指标)与手动…

    2025年12月20日
    000
  • JavaScript数据库操作优化

    通过减少网络请求、合理使用缓存、优化本地数据处理和提升IndexedDB效率,可显著提升前端数据操作性能。 JavaScript本身不直接操作传统意义上的数据库(如MySQL、PostgreSQL),但在前端或Node.js环境中,我们常通过API与后端数据库交互,或在浏览器中使用IndexedDB…

    2025年12月20日
    000
  • 统计其他 Discord Bot 命令的使用次数

    本文介绍如何使用 Python 和 Discord.py 库来统计特定用户使用其他 Discord Bot 命令的次数,例如 DISBOARD 的 !bump 命令。主要通过两种方法实现:一是监听所有消息并检查命令,二是创建一个具有相同命令的 Bot 来同步触发。本文将重点讲解第二种方法,并提供示例…

    2025年12月20日
    000
  • 构建多租户应用:利用子域名和主机头实现单一部署与数据隔离

    本文探讨如何利用子域名和http主机头实现多租户应用的单一部署与数据隔离。通过识别请求中的子域名来确定租户,进而路由到对应的数据库或数据源,确保每个租户拥有独立的动态数据,同时共享一套核心应用代码。这种策略极大地简化了应用更新和维护,适用于remix等现代web框架。 一、理解多租户架构与挑战 多租…

    2025年12月20日
    000
  • 从数据库获取数据并在日历中显示:完整教程

    本文档旨在指导开发者如何从数据库中获取事件数据,并将其集成到 javascript 日历中进行可视化展示。我们将重点讲解如何使用 jquery 和 php 从数据库中提取数据,并将其转换为日历组件能够识别的事件格式,最终实现动态更新日历事件的功能。 ### 1. 数据准备与后端接口首先,我们需要一个…

    2025年12月20日
    000
  • 使用 Knex 从 MySQL datetime 列按日期选择数据

    本文介绍了如何使用 Knex.js 从 MySQL 数据库的 datetime 列中按日期选择数据。重点讲解了 `whereRaw` 方法的使用,并通过示例代码演示了如何进行参数绑定和直接插入值两种方式,帮助开发者灵活地实现日期查询需求。 在使用 Knex.js 与 MySQL 数据库交互时,经常需…

    2025年12月20日
    000
  • 从数据库加载数据并在日历中显示事件

    本文档旨在指导开发者如何从数据库中获取事件数据,并将其动态地展示在日历控件上。我们将重点解决数据格式转换、异步加载以及与现有日历代码集成的常见问题,并提供可执行的代码示例,帮助您快速实现数据库驱动的日历功能。 ### 前提条件在开始之前,请确保您已具备以下条件:* 熟悉 HTML、CSS 和 Jav…

    2025年12月20日
    000
  • 在Node.js中,如何构建一个高并发的RESTful API服务器?

    使用Fastify框架并启用集群模式,结合Redis缓存、数据库连接池、限流熔断及Nginx反向代理,充分发挥Node.js异步非阻塞特性以构建高并发RESTful API服务。 构建一个高并发的 RESTful API 服务器,关键在于性能优化、稳定性保障和良好的架构设计。Node.js 天生适合…

    2025年12月20日 好文分享
    000
  • Knex 中从 MySQL DATETIME 列按日期筛选数据的技巧

    本教程旨在解决使用 knex 从 mysql 的 datetime 类型列中仅按日期部分筛选数据的常见问题。我们将探讨直接使用 date() 函数失败的原因,并详细介绍如何利用 knex 的 whereraw 方法实现安全有效的日期筛选,同时提供参数绑定和直接插入值的示例及注意事项。 Knex 中从…

    2025年12月20日
    000
  • 使用 Knex.js 根据日期查询 MySQL datetime 列的数据

    本文介绍了如何使用 Knex.js 查询 MySQL 数据库中 `datetime` 类型列,并根据日期进行筛选。核心方法是使用 `whereRaw` 函数执行原生 SQL 语句,从而利用 MySQL 的 `date()` 函数提取日期部分进行比较。文章提供了两种 `whereRaw` 的使用方式,…

    2025年12月20日
    000
  • 如何用Node.js构建一个高并发的后端服务?

    构建高并发Node.js服务需选用Fastify框架、启用集群模式、优化数据库访问并引入Redis缓存,结合Nginx负载均衡与PM2进程管理,通过监控和限流保障系统稳定。 构建一个高并发的后端服务,关键在于充分利用 Node.js 的非阻塞 I/O 和事件循环机制,同时结合合理的架构设计和性能优化…

    2025年12月20日
    000
  • Knex.js中如何通过日期筛选MySQL datetime列数据

    本教程详细介绍了在knex.js中,如何从mysql的`datetime`类型列中,仅根据日期部分进行数据筛选。针对直接使用`date()`函数报错的问题,文章提供了两种基于`whereraw`方法的解决方案,并强调了参数绑定的重要性,确保查询的安全性与准确性。 在数据库操作中,我们经常需要根据日期…

    2025年12月20日
    100
  • Knex.js 中从 MySQL datetime 列按日期筛选数据的实用指南

    本教程旨在解决 knex.js 在 mysql 中按日期筛选 `datetime` 类型列数据时遇到的挑战。针对 knex 直接调用 `date()` 函数的限制,文章详细阐述了如何利用 `whereraw` 方法实现这一功能,并提供了两种实现方式:安全的参数绑定和便捷的直接值插入。同时,强调了在使…

    2025年12月20日
    000
  • Django 迁移后仍出现 INTEGRITY ERROR:列已不存在的解决方案

    本文旨在解决 Django 项目中,在模型字段删除并执行迁移后,仍然出现 `IntegrityError`,提示某列(已删除)违反非空约束的问题。我们将探讨问题原因,并提供详细的排查和修复步骤,确保数据一致性和应用正常运行。 在 Django 开发过程中,我们经常需要修改模型(models.py)并…

    2025年12月20日
    000
  • Django 迁移后出现IntegrityError:列不存在的解决方案

    在使用 Django 开发过程中,经常会遇到修改 Model 后需要进行数据库迁移的情况。但有时即使执行了迁移,仍然会出现 `IntegrityError`,提示某个已删除的列仍然存在约束。本文将详细介绍出现这种错误的原因以及如何解决,确保数据库与 Model 定义保持同步,避免数据一致性问题。 问…

    2025年12月20日
    000
  • 高效管理多组复选框:动态数据绑定与显示教程

    本教程详细阐述如何使用原生javascript、语义化html和现代css有效管理多个独立的复选框组,并将它们的选择结果动态地显示在各自的文本字段中。通过事件委托、dom操作和css自定义属性,我们构建了一个可扩展、高性能且易于维护的解决方案,避免了全局选择器带来的问题,并为数据持久化到数据库奠定了…

    2025年12月20日
    000
  • 如何用Node.js实现一个高效的爬虫系统?

    高效Node.js爬虫需选合适库如axios+cheerio或Puppeteer,用p-limit控制并发数并加随机延迟,设置请求头、轮换代理IP应对反爬,结合Redis去重、数据库存储,用node-cron调度任务,确保稳定可持续运行。 构建一个高效的 Node.js 爬虫系统,关键在于合理选择工…

    2025年12月20日
    000
  • JavaScript中的模板字符串如何实现SQL查询构建器?

    JavaScript中可通过标签模板结合参数化查询安全构建SQL语句。定义sql标签函数将模板解析为静态片段与动态值分离的结构,避免拼接字符串导致的SQL注入。例如sql函数将${name}等变量替换为$1类占位符,并返回包含text和values的对象,供数据库驱动执行。对于动态条件,可封装逻辑按…

    2025年12月20日
    000
  • 如何解决 Strapi 项目中团队成员无法获取页面数据的问题

    第一段:本文旨在解决 Strapi 项目中,团队成员从 GitHub 拉取代码后无法获取后端数据的问题。通过分析数据存储位置和权限配置,提供了一种安全的共享数据库方案,避免潜在的冲突和问题,确保团队成员能够顺利访问和使用后端数据。 在 Strapi 项目开发中,经常会遇到团队成员从版本控制系统(如 …

    2025年12月20日
    000
  • 如何实现一个支持差分更新的数据同步策略?

    实现差分更新需先识别数据变更,再仅同步变化部分。1. 通过时间戳、版本号、增量日志或状态标记识别变更;2. 客户端发送最新同步点,服务端返回该点后新增、修改、删除的变更集,支持分页与压缩;3. 客户端按操作类型顺序应用变更,使用事务保证一致性,并更新本地同步元数据;4. 为提升可靠性,应支持断点续传…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信