MySQL中其他函数的简介

63次阅读
没有评论

共计 4899 个字符,预计需要花费 13 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关 MySQL 中其他函数的简介,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

其他函数

(1)格式化函数 format(x,n)
(2)不同进制的数字进行转换的函数
(3)IP 地址与数字相互转换的函数
(4)加锁函数与解锁函数
(5)重复执行指定操作的函数
(6)改变字符集的函数
(7)改变数据类型的函数

(1)、格式化函数 format(x,n)

format(x,n)将数字 x 格式化,并以四舍五入的方式保留小数点后 n 位,结果以字符串的形式返回。若 n 为 0,则返回结果函数不含小数部分。

mysql  select format(12332.123456,4),format(12332.1,4),format(12332.2,0);+------------------------+-------------------+-------------------+| format(12332.123456,4) | format(12332.1,4) | format(12332.2,0) |+------------------------+-------------------+-------------------+| 12,332.1235 | 12,332.1000 | 12,332 |+------------------------+-------------------+-------------------+1 row in set (0.00 sec)

(2)、不同进制的数字进行转换的函数

conv(n,from_base,to_base)函数进行不同进制数之间的转换, 若有一个参数为 null, 则返回值为 null。

【例】使用 conv 函数在不同进制数值之间转换,SQL 语句如下:

mysql  select conv(a ,16,2),
 -  conv(15,10,2),
 -  conv(15,10,8),
 -  conv(15,10,16);+----------------+---------------+---------------+----------------+| conv(a ,16,2) | conv(15,10,2) | conv(15,10,8) | conv(15,10,16) |+----------------+---------------+---------------+----------------+| 1010 | 1111 | 17 | F |+----------------+---------------+---------------+----------------+1 row in set (0.01 sec)

进制说明二进制采用 0 和 1 两个数字来表示的数,以 2 为基数,逢二进一八进制采用 0 - 7 八个数字,逢八进一,以数字 0 开头十进制采用 0 - 9 共十个数字表示,逢十进一十六进制由 0 -9,A- F 组成,与十进制的对应关系是:0- 9 对应 0 -9,A- F 对应 10-15,十六进制数以 0x 开头(3)、IP 地址与数字相互转换的函数

1.inet_aton()

inet_aton(expr)给出一个作为字符串的网络地址的点地址表示,返回一个代表该地址数值的整数,地址可以是 4bit 或 8bit 地址。

【例】使用 inet_aton()函数将字符串网络点地址转换为数值网络地址,SQL 语句如下:

产生的数字按照网络字节顺序计算,此例子计算方法为:209*256^3+207*256^2+224*256+40。

mysql  select inet_aton(209.207.224.40 +-----------------------------+| inet_aton( 209.207.224.40) |+-----------------------------+| 3520061480 |+-----------------------------+1 row in set (0.00 sec)

2.inet_ntoa()

inet_ntoa(expr)给定一个数字网络地址(4bit 或 8bit),返回作为字符串的该地址的点地址表示。

inet_ntoa 函数与 inet_aton 互为反函数。

【例】使用 iner_ntoa 函数将数值网络地址转换为字符串网络点地址,SQL 语句如下:

mysql  select inet_ntoa(3520061480);+-----------------------+| inet_ntoa(3520061480) |+-----------------------+| 209.207.224.40 |+-----------------------+1 row in set (0.00 sec)

(4)、加锁函数与解锁函数

1.get_lock(str,timeout)设法使用字符串 str 给定的名字得到一个锁,超时为 timeout 秒。若成功得到锁,则返回 1;若操作超时返回 0;若发生错误,返回 null。
假如有一个用 get_lock()得到的锁,当执行 release_lock()或链接断开 (正常或非正常) 时,这个锁就会解除。

2.release_lock(str)解开被 get_lock()获取的,用字符串 str 所命名的锁。若锁被解开,则返回 1;若该线程尚未创建锁,则返回 0(此时锁没有被解开); 若命名的锁不存在,则返回 null。若该锁从未被 get_lock()的调用获取,或锁已经被提前解开,则该锁不存在。

3.is_free_lock(str)检查名为 str 的锁是否可以使用(没有被封锁)。若锁可以使用,则返回 1(没有人在使用这个锁); 若这个锁正在被使用,则返回 0;出现错误,则返回 null(诸如不正确的参数)。

4.is_used_lock(str)检查名为 str 的锁是否正在被使用(被封锁)。若被封锁,则返回使用该锁的客户端的连接标识符(connectionID); 否则,返回 null。

【例】使用加锁、解锁函数,SQL 语句如下:

mysql  select get_lock(lock1 ,10) as getlock,
 -  is_used_lock(lock1) as isusedlock,
 -  is_free_lock(lock1) as isfreelock,
 -  release_lock(lock1) as releaselock;+---------+------------+------------+-------------+| getlock | isusedlock | isfreelock | releaselock |+---------+------------+------------+-------------+| 1 | 21 | 0 | 1 |+---------+------------+------------+-------------+1 row in set (0.05 sec)

(5)、重复执行指定操作的函数

– benchmark(count,expr)函数重复执行表达式(expr)count 次。它可以用于计算 MySQL 处理表达式的速度。结果值通常为 0,(0 只是表示处理过程很快,并不是没有花时间)。另一个作用是它可以在 MySQL 客户端内部报告语句执行的时间。

【例】使用 benchmark 重复执行指定函数

可以看到下面语句执行 500000 次的时间为 0.38sec,明显比执行一次的时间提高了。

mysql  select md5(Hudie +----------------------------------+| md5( Hudie) |+----------------------------------+| 3fe2017e5cb984400c5271ef77a840f6 |+----------------------------------+1 row in set (0.00 sec)mysql  select benchmark(500000,md5( Hudie +--------------------------------+| benchmark(500000,md5( Hudie)) |+--------------------------------+| 0 |+--------------------------------+1 row in set (0.38 sec)

注意:
benchmark 报告的时间是客户端经过的时间,而不是在服务器端的 CPU 时间,每次执行后报告的时间并不一定是相同的。

(6)、改变字符集的函数

convert(…using…)带有 using 的 convert()函数被用来在不同的字符集之间转化数据。

【例】使用 convert()函数改变字符串的默认字符集,SQL 语句如下;

mysql  select charset( string ),charset( convert(  string   using latin1 ) );+---------------------+----------------------------------------------+| charset( string ) | charset( convert(  string   using latin1 ) ) |+---------------------+----------------------------------------------+| gbk | latin1 |+---------------------+----------------------------------------------+1 row in set (0.00 sec)

默认为 gbk 字符集,通过 convert 将字符串 strng 的默认字符集改为 latin1。

(7)、改变数据类型的函数

– case(x,as type)和 convert(x,type)函数将一个类型的值转换为另一个类型的值, 可以转换的 type 值有 binary、char(n)、date、time、datetime、decimal、signed、unsigned。

【例】使用 case 和 convert 函数进行数据类型的转换,SQL 语句如下:

mysql  select cast(100 as char(2)),convert( 2019-08-20 00:32:01  ,time);+----------------------+---------------------------------------+| cast(100 as char(2)) | convert( 2019-08-20 00:32:01  ,time) |+----------------------+---------------------------------------+| 10 | 00:32:01 |+----------------------+---------------------------------------+1 row in set, 1 warning (0.05 sec)

可以看到,case(100 as char(2))将整数数据类型 100 转换为带有两个显示宽度的字符串类型,结果为“10”;convert(‘2010-08-20 00:32:01’)将 datetime 类型的值转换为 time 类型,结果为 00:32:01。

关于“MySQL 中其他函数的简介”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计4899字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)