startindex 不能大于字符串长度_「12」学习MySQL第二类函数:字符串函数

前一篇文章总结了下MySQL中常用的数学函数,本文接下来的重点就是认识“字符串函数”。

024bd616a84744a0776f8ad55d944007.png

上图这匹漂亮的马儿就是通过各种字符(字母、括号、逗号、竖线等)画出来的。我不由自主地会去想下面几个问题:

  1. 它到底有多少个字符?--字符串长度
  2. 它里面的小写字母改成大写后视觉效果如何?--大小写转换
  3. 有些地方的空格去掉会如何?--去掉空格符
  4. 某些地方插入一些其他字符?--填充字符
  5. 找到某个特定字符的位置?--匹配字符位置
  6. ……

当然每个人可以各自发挥想象。但不管问多少问题,我们最终都要看看字符串函数是否能解决--这就是学习的目的所在!

人生,何尝不是一个面对问题与找答案的循环往复的过程啊!

74385c04bd95396e4bd7e75941be061f.png

【1】计算字符串字符数:CHAR_LENGTH(str)

【规则】返回字符串str中所包含的字符的个数。

75c66df9ff202a48993acbf72ef1c72a.png

【结论】一个英文字母和一个汉字都算作一个字符。

【2】计算字符串长度:LENGTH(str)

【规则】计算str的长度。

8d5c89dcd54ca5dcb6a610a59773cffb.png

【结论】英文字母与汉字的字符长度计算规则不一样。

【3】字母大小写 转换

  • LOWER(str)或LCASE(str)可以将str转化为小写字母;
  • UPPER(str)或UCASE(str)可以将str转化为大写字母。
4b4626e5a7de4dd2558892707ed0018d.png

【4】删除空格函数

  • 删除左侧空格:LTRIM(str)
  • 删除右侧空格:RTRIM(str)
  • 删除两端空格:TRIM(str)
d70276bc97cadbc8fee94c01d76deab3.png

【5】填充字符串函数:LPAD(s1,len,s2)

【规则】该函数返回字符串s1,其左侧由字符串s2填充,填充的长度为len。如果s1的长度大于len,则返回值被缩短至len个字符。

5b4805837c4b0d943ca7745444bfcce7.png

【结论】

  • s1的长度大于len,则从s1从左侧开始截取len个字符作为返回值;
  • s1与s2的长度之和小于等于len,则将s2插入s1左侧后全部返回;
  • s1与s2的长度之和大于len,则将s2从左侧开始截取len-length(s1)个数插入s1左侧后作为返回值。

【6】获取指定长度的字符

  • LEFT(str,len):返回字符串str最左边的len个字符;
  • RIGHT(str,len):返回字符串str最由边的len个字符。
a847aa77c52ed3d33719ef3b188ff556.png

【7】替换字符串的函数:INSERT(s1,x,len,s2)

【规则】返回字符串s1,s1中起始于x位置、长度为len的子字符串将被s2取代。

如果x超过字符串长度,则返回值为s1;如果len的长度大于x位置后字符串的总长度,则从位置x开始替换。若任何一个参数为NULL,则返回值必定为NULL。

8b9255070d9cf50544d3618a00254773.png

【结论】x为负数也表示超出了字符串s1的长度。

总结

  • 本文列举了7类函数;
  • 所列举的函数解决了文章开头提出的5大问题;
  • 还有一类重要的字符串函数--字符串合并或字符串拼接--留待有机会单独一篇文章来写。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/352140.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

对数函数的C、MATLAB表示

1、C语言中的对数函数 头文件:#include格式:①double log (double x);log() 函数返回以 e 为底的对数值,即数学中的lnx;如果 x 为负数或 0,则会发生错误并设置 errno 值。错误代码:EDOM:参数x 为…

微信小程序开发——超链接或按钮点击跳转到其他页面失效

1. 超链接导航失效: 小程序规则——wx.navigateTo 和 wx.redirectTo 不允许跳转到 tabbar 页面,只能用 wx.switchTab 跳转到 tabbar 页面转载于:https://www.cnblogs.com/xyyt/p/9252835.html

javaone_JavaOne 2012:Lambda之路

javaone我最热切期待的JavaOne 2012演讲之一是Brian Goetz的“通往Lambda的道路”。 昨晚的技术主题演讲中的Lambda味道仅增加了预期。 这是在希尔顿广场A / B举行的,距离我之前在金门大桥A / B / C参加的演讲仅几步之遥。 我曾预计会打包相对较大的Plaza A / B&…

uml 时序图_UML各种图总结:

UML的书籍:《UML distilled》、《UML和模式应用》、《UML用户指南》、《UML对象设计与编程》、《UMLOracle8建模》UML(Unified Modeling Language)是一种统一建模语言,为面向对象开发系统的产品进行说明、可视化、和编制文档的一种…

让程序结果在屏幕上暂停一段时间

现在使用VS2013输出printf显示结果&#xff0c;经常会出现一闪而过的情况&#xff0c;现有以下解决办法&#xff1a; 1.调用系统命令暂停 #include <stdlib.h>system("pause");2. #include<conio.h> getchar(); 3. #include<stdlib.h> getchar(); …

Linux shell的标准输入、输出和错误

1.文件描述符 在linux shell执行命令时&#xff0c;每个进程都和三个打开的文件相联系&#xff0c;并使用文件描述符来引用这些文件。由于文件描述符不容易记忆&#xff0c;shell同时也给出了相应的文件名&#xff1a; 文件文件描述符输入文件—标准输入0&#xff08;缺省是键…

微基准测试进入Java 9

我已经几个月没有在这里写文章了&#xff0c;这种例外也会继续下去。 我计划在明年三月左右恢复写作。 本文末尾的说明。 等待&#xff01; 不完全是最后&#xff0c;因为您可以向下滚动。 它在文章结尾处。 继续阅读&#xff01; 三年前&#xff0c;我在写有关Java编译器如何…

摆渡车(noip2018 pj t3)

摆渡车&#xff08;题目和测试右转 洛谷P5017&#xff09; 做法&#xff1a;dp各种优化(剪枝) 这道题考场上看了一脸懵逼...第一眼看这 tm 不是个一维dp吗...结果按着这个朦胧的思路&#xff0c;删删改改约莫0.5h&#xff0c;终于过了小样例&#xff0c;然后一测大样例...GG了。…

关于树的冷知识

1、为什么冬天树干刷白漆&#xff1f; 刷的是是石灰水&#xff0c;主要成分是石灰乳,还有食盐,大豆粉,石榴合剂。 好处一、石灰具有一定的杀菌、杀虫作用&#xff0c;可以杀死寄生在树干上的一些越冬的真菌、细菌和害虫。 好处二、由于害虫一般都喜欢黑色、航脏的地方&#x…

乐玩自动化测试模块_自动化测试模型(一)自动化测试模型介绍

一个自动化测试框架就是一个集成体系&#xff0c;在这一体系中包含测试功能的函数库&#xff0c;测试数据源&#xff0c;测试对象标准&#xff0c;以及各种可重用的模块。自动化测试在发展过程中经历了以下几个阶段&#xff0c;模块驱动测试&#xff0c;数据驱动测试及对象驱动…

linux特殊权限位之setuid、setgid和sticky

我们登陆到系统之后,创建一个普通文件或者目录的时候,会有一个默认的权限。普通文件是644,目录文件是755,想必大家都知道这个是由umask这个值决定的。我们可以直接执行umask命令查看&#xff0c;linux系统默认的umask值是0022。想改变创建文件默认的权限&#xff0c;我们直接修…

js获取当前时间,并实时更新

可以使用JavaScript的Date()对象来获取当前时间&#xff0c;并使用setInterval()函数实现实时更新。 以下是一个示例代码&#xff1a; <p id"time"></p>function updateTime() {var now new Date();var hours now.getHours();var minutes now.getMi…

11.23日常

整理相关资料&#xff0c;阅读c#课本转载于:https://www.cnblogs.com/JL3Peanut/p/10032318.html

python requests 10041报错_pythonrequests返回unicode异常消息(或如何设置请求区域设置)...

您可以尝试os.strerror&#xff0c;但它可能不会返回任何内容或相同的非英语字符串。在ENGLISH_WINDOWS_SOCKET_MESSAGES {10004: "Interrupted function call.",10013: "Permission denied.",10014: "Bad address.",10022: "Invalid argu…

深度学习(花书)

1.英文主页http://www.deeplearningbook.org/lecture_slides.html 2.中文主页https://github.com/exacity/deeplearningbook-chinese 在线阅读https://exacity.github.io/deeplearningbook-chinese/转载于:https://www.cnblogs.com/Eufisky/p/10010046.html

表面配准论文1--基于高阶图匹配方法的稠密表面配准

Dense Non-rigid Surface Registration Using High-Order Graph Matching 一.摘要提出高阶图匹配方程来解决非刚性表面配准问题&#xff0c;单阶项描述了几何和外观相似性&#xff08;曲率和纹理&#xff09;&#xff0c;高阶项对内部嵌入能量&#xff08;intrinsic embedding …

Apache Spark软件包,从XML到JSON

Apache Spark社区为扩展Spark付出了很多努力。 最近&#xff0c;我们希望将XML数据集转换为更易于查询的内容。 我们主要对每天进行的数十亿笔交易之上的数据探索感兴趣。 XML是一种众所周知的格式&#xff0c;但是有时使用起来可能很复杂。 例如&#xff0c;在Apache Hive中&a…

js中几种实用的跨域方法原理详解

这里说的js跨域是指通过js在不同的域之间进行数据传输或通信&#xff0c;比如用ajax向一个不同的域请求数据&#xff0c;或者通过js获取页面中不同域的框架中(iframe)的数据。只要协议、域名、端口有任何一个不同&#xff0c;都被当作是不同的域。 下表给出了相对http://store.…

python中matplotlib画图_Python-matplotlib画图(莫烦笔记)

这个是我对于莫烦老师的matplotlib模块的视频做的一个笔记。1.前言Matplotlib是一个python的 2D绘图库&#xff0c;它以各种硬拷贝格式和跨平台的交互式环境生成出版质量级别的图形。通过Matplotlib&#xff0c;开发者可以仅需要几行代码&#xff0c;便可以生成绘图&#xff0c…