V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
makeitclear
V2EX  ›  MySQL

mysql 怎么把字符串中的中文替换掉?

  •  
  •   makeitclear · 2020-12-23 16:10:42 +08:00 · 1759 次点击
    这是一个创建于 1422 天前的主题,其中的信息可能已经有所发展或是发生改变。

    表中有一列数据 roomName 是这样的:

    2 号教学组团 0208
    3 号教学楼 0234
    2 号教学组团 0315
    11 号教学楼 0518
    (某某学院专用) 11 号教学楼 0306
    ……
    

    想把他们转换成下边这样的:

    2-208
    3-234
    2-315
    11-518
    11-306
    ……
    

    大家有没有好的办法?

    4 条回复    2020-12-23 16:53:33 +08:00
    maocat
        1
    maocat  
       2020-12-23 16:16:31 +08:00
    mysql 直接把业务也做了,嗨呀
    totoro52
        2
    totoro52  
       2020-12-23 16:44:46 +08:00
    一楼笑死我了
    wysnylc
        3
    wysnylc  
       2020-12-23 16:51:28 +08:00
    重生之我在 2010 写存储过程
    wjfz
        4
    wjfz  
       2020-12-23 16:53:33 +08:00
    # 先把中文弄成问号,然后把问号替换掉
    UPDATE stops SET `name` = REPLACE(CONVERT(`name` USING ASCII),'?','');

    # 再把两个空格替换成-
    UPDATE stops SET `name` = REPLACE(`name`,' ','-');

    # 最左边有可能有空格,弄掉
    UPDATE stops SET `name` = REPLACE(`name`,' ','');
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5403 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 03:43 · PVG 11:43 · LAX 19:43 · JFK 22:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.