MySQL 中修改字段的首字母为大写

发布于 2019-10-24 21:59:03 字数 1729 浏览 2990 评论 0

英文的单纯一般首个字母都是大写的,虽然 MySQL 中有转换大小写字母的函数,但是那是对整个字段都进行转换,如果需要将字段中首字母大写却没有直接的函数,不过我们可以使用其它的函数将字符串切割,再转换为大写,最后再拼接字符串即可。

使用到的函数

  • CONCAT(str1,str2):字符连接函数
  • UPPER(str):将字符串改为大写字母
  • LOWER(str):将字符串改为小写字母
  • LENGTH(str):判定字符串长度
  • SUBSTRING(str,a,b):提取字段中的一段,从字符串str的第a位开始提取,提取b个字符
  • LEFT(str,n):提取字符串最左边的n个字符
  • RIGHT(str,n):提取字符串最右边的n个字符(该例未用到)

解决思路

  • 用LEFT单独将首字母取出并用UPPER换成大写
  • 确定字段的长度,并用SBUSTRING取出从第二位到最后一位的所有字段备用。
  • 用CONCAT连接上边的两个值
  • update表中字段的值即可。

解决方法

我们先来看看我们的表中有那些数据。

mysql> select ename from emp;
+--------+
| ename  |
+--------+
| zzx    |
| lisa   |
| bjguan |
| dony   |
| bzshen |
+--------+
5 rows in set (0.00 sec)

执行我们编写的SQL语句

mysql> update emp set ename=concat(UPPER(left(ename,1)),substring(ename,2,(length(ename)-1)));
Query OK, 5 rows affected (0.00 sec)
Rows matched: 5  Changed: 5  Warnings: 0

再次查询查看我们执行的结果

mysql> select * from emp;
+--------+------------+---------+--------+
| ename  | hiredate   | sal     | deptno |
+--------+------------+---------+--------+
| Zzx    | 2000-01-01 |  100.00 |      1 |
| Lisa   | 2003-02-01 |  400.00 |      2 |
| Bjguan | 2004-04-02 |  100.00 |      1 |
| Dony   | 2005-02-05 | 2000.00 |      4 |
| Bzshen | 2005-04-01 | 4000.00 |      3 |
+--------+------------+---------+--------+
5 rows in set (0.00 sec)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

0 文章
0 评论
84961 人气
更多

推荐作者

qq_aHcEbj

文章 0 评论 0

寄与心

文章 0 评论 0

13545243122

文章 0 评论 0

流星番茄

文章 0 评论 0

春庭雪

文章 0 评论 0

潮男不是我

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文