午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

mysql根據(jù)某個字段已存在的值排序

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

問題描述

因為之前數(shù)據(jù)庫結(jié)構(gòu)沒設(shè)計好,導(dǎo)致現(xiàn)在數(shù)據(jù)很混亂。1.就比如下面那個 values 字段,想讓他里面從小到大的排序。比如第一個變成 ['133','136','257']我知道php能做,但是我現(xiàn)在想研究一下mysql相關(guān)的函數(shù),請問是否有支持的。。

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

mysql根據(jù)某個字段已存在的值排序

問題解答

回答1:

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

例如可以這樣:

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);

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

MySQL 5.7支持JSON了,把字段轉(zhuǎn)成JSON也許可以。

回答2:

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

回答3:

靠mysql應(yīng)該沒什么辦法,寫個腳本處理下吧。

相關(guān)文章:
主站蜘蛛池模板: www.欧美com | 激情久久综合 | 三级三级久久三级久久18 | av资源在线看| 日韩午夜激情 | 国产精品一区二区三区免费视频 | 亚洲黄色片子 | 国产成人三级在线播放 | 亚洲精品成人av久久 | 日韩国产在线 | 999久久精品| 日韩一区二区三区免费观看 | 日韩少妇视频 | 日韩大片在线观看 | 日韩精品无| 国产精品一区二区视频 | 精品久久伊人 | 色婷av| 午夜精品久久久 | 午夜影院体验区 | 99国产精品久久久久久久成人热 | 一区二区三区视频在线免费观看 | 欧美国产精品一区二区 | 五月中文字幕 | 超碰2019| 欧美三级欧美一级 | 黄色欧美大片 | 国产 中文 字幕 日韩 在线 | 可以在线观看的av | 亚洲国产精品久 | 日韩av片在线免费观看 | 欧美在线不卡视频 | 午夜aaa| 午夜伦理网 | 欧美伊人影院 | 免费观看黄色一级视频 | 天堂av中文在线 | 蜜桃91丨九色丨蝌蚪91桃色 | 五月天综合激情 | 日女人逼视频 | 日本三级视频在线播放 |