国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

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

問題描述

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

因?yàn)槲抑白?批量更新的時(shí)候,就發(fā)現(xiàn)mysql有這個(gè)辦法,感覺很強(qiáng)大

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

問題解答

回答1:

寫個(gè)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è)計(jì)的的時(shí)候就應(yīng)該保證這個(gè)值的原子性、這是設(shè)計(jì)上的失誤,mysql不會為這種失誤出解決方案吧

回答3:

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

相關(guān)文章:
主站蜘蛛池模板: 日本欧美大片 | 一二三区视频 | 亚洲国产精品欧美日韩一区二区 | 亚洲天堂久久久 | 黄毛片一级毛片 | 韩日一区二区 | 18视频免费网址在线观看 | 国产乱子伦露脸对白在线小说 | 欧美精品a毛片免费观看 | 国产亚洲精品久久久久91网站 | 国产免费播放一区二区 | avav在线看| a毛片网站 | 九九九九热精品视频 | 爽爽视频在线观看 | 亚洲小视频在线 | 国产色视频在线观看免费 | 欧美三级 欧美一级 | 99久久精品国产综合一区 | 欧美精品不卡 | 欧美一区二区三区激情视频 | 在线播放精品一区二区啪视频 | 99re在线视频精品 | 亚洲图片偷拍区 | 久久精品视 | 黄色成人在线观看 | 成年人视频网站免费 | 亚洲视频免费在线 | 久久精品免费一区二区视 | 在线三级网址 | 丁香婷婷影音先锋5566 | 日本强不卡在线观看 | 东京一区二区三区高清视频 | 亚洲国产精品影院 | 亚洲 欧美 日韩 丝袜 另类 | 三级网站视频 | 国产成人精品男人的天堂538 | 欧美亚洲日本 | 一级视频在线播放 | 国产成人一区二区三中文 | 欧美色成人tv在线播放 |