MySQL 中修改字段的首字母为大写
英文的单纯一般首个字母都是大写的,虽然 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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论