亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

mysql根據某個字段已存在的值排序

瀏覽:83日期:2022-06-14 16:45:36

問題描述

因為之前數據庫結構沒設計好,導致現在數據很混亂。1.就比如下面那個 values 字段,想讓他里面從小到大的排序。比如第一個變成 ['133','136','257']我知道php能做,但是我現在想研究一下mysql相關的函數,請問是否有支持的。。

因為我之前做 批量更新的時候,就發現mysql有這個辦法,感覺很強大

mysql根據某個字段已存在的值排序

問題解答

回答1:

寫個MySQL函數,在里面拆字符串,排序。

例如可以這樣:

CREATE FUNCTION `sort_col`(`input` VARCHAR(50)) RETURNS VARCHAR(50) LANGUAGE SQL NOT DETERMINISTIC NO SQL SQL SECURITY DEFINER COMMENT ’’BEGINdeclare a int;declare b int;declare c int;set a = cast(substr(input, 3, 3) as int);set b = cast(substr(input, 9, 3) as int);set c = cast(substr(input, 15, 3) as int);if (a <= b && b <= c) then return concat(’['’, a, ’','’, b , ’','’, c , ’']’);elseif (b <= a && a <= c) then return concat(’['’, b, ’','’, a , ’','’, c , ’']’);elseif (c <= a && a <= b) then return concat(’['’, c, ’','’, a , ’','’, b , ’']’);elseif (c <= b && b <= a) then return concat(’['’, c, ’','’, b , ’','’, a , ’']’);elseif (a <= c && c <= b) then return concat(’['’, a, ’','’, c , ’','’, b , ’']’);elseif(b <= c && c <= a) then return concat(’['’, b, ’','’, c , ’','’, a , ’']’);end if;END

然后就可以更新了:

update table_name set values = sort_col(values);

(上面的函數假設了數字都是3位,不用直接用哦)

MySQL 5.7支持JSON了,把字段轉成JSON也許可以。

回答2:

表設計的的時候就應該保證這個值的原子性、這是設計上的失誤,mysql不會為這種失誤出解決方案吧

回答3:

靠mysql應該沒什么辦法,寫個腳本處理下吧。

相關文章:
主站蜘蛛池模板: 啪啪中文字幕 | 国产在线视频www色 国产在线视频一区 | 久久青草免费免费91线频观看 | 免费的看黄网站 | 夜夜爱成人免费网站 | 亚洲精品视频在线观看视频 | 香蕉97超级碰碰碰免费公 | 免费观看黄色 | 中文永久免费看电视网站入口 | 午夜国产福利视频 | 黄色毛片在线观看 | xzl仙踪林一区| 欧美性生活视频 | 国产免费又色又爽又黄在线观看 | 91久久精品日日躁夜夜躁欧美 | 在线一级视频 | 日韩国产欧美一区二区三区 | 国产亚洲欧美日韩在线观看不卡 | 含羞草1000成人免费视频 | 好大水好多好爽好硬好深视频 | 妞干网在线视频观看 | 久久er热视频在这里精品 | 中国黄色三级 | 成人在线观看午夜 | 那个网站可以看毛片 | 在线观看www视频 | 国产色在线com| 久久青草91免费观看 | 色y视频 | 日韩毛片网 | 国产日韩欧美在线一二三四 | 黄色国产一级片 | 国产私拍精品88福利视频 | 全免费午夜一级毛片真人 | 精品国产免费一区二区三区五区 | 日韩中文字幕a | 一级女性全黄生活片免费看 | 女性一级全黄生活片 | 北条麻妃99精品青青久久 | 亚洲图片综合区 | 在线观看激情偷拍视频 |