<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Dict.CN 在線詞典, 英語學習, 在線翻譯

    都市淘沙者

    荔枝FM Everyone can be host

    統計

    留言簿(23)

    積分與排名

    優秀學習網站

    友情連接

    閱讀排行榜

    評論排行榜

    Mysql 實現split字符串分割


    --場景大致如下:有A B兩表,A表中的某一字段bids存放著一個B表主鍵的數組如3,4,5 而這個時候要做關聯查詢的時候,理想情況應該可以這樣做
    select b.* from A a,B b where b.id in (a.bids.split(',')) 但是mysql并不支持這樣做,也沒有提供類似的做法,所以很糟糕。 有一種變態的做法就是給bids做一下處理,就是
    在bids的前后都加上逗號, 這樣bids就變成,3,4,5, 這個時候利用模糊查詢來做關聯就可以達到目的了,做法如下:
    select b.* from A a, B b where CONCAT(CONCAT(',',a.bids),','LIKE CONCAT(CONCAT('%,',b.id),',%'

    當b的id
    =3時候的查詢相當于執行
    select b.* from A a, B b where  ',3,4,5,' LIKE  '%,3,%'

    ----真實例子----
    SELECT t.*
    FROM tea_material_trade t ,tea_process_product p WHERE p.id =2 AND  CONCAT(CONCAT(',',p.tradeids),','LIKE CONCAT(CONCAT('%,',t.id),',%'


    --值得注意的是,這樣的效率恐怕比較低,小數據量應該沒有問題,大數據量估計不能這么做



    mysql像個蛋一樣,連基本的函數都不提供,難怪被oracle買了。只有通過存儲過程來搞,郁悶得不行。

    DELIMITER $$

    USE `teasys`$$

    DROP PROCEDURE IF EXISTS `proc_split`$$

    CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_split`(
        inputstring 
    VARCHAR(1000),
        delim 
    CHAR(1)
    )
    BEGIN
        
    DECLARE strlen INT;
        
    DECLARE last_index INT;
        
    DECLARE cur_index INT;
        
    DECLARE cur_char VARCHAR(200);
        
    DECLARE len INT;
        
    SET cur_index=1;
        
    SET last_index=0;
        
    SET strlen=LENGTH(inputstring);  
        
    DROP TABLE IF EXISTS splittable;
        
    CREATE TEMPORARY TABLE splittable(
            id 
    INT AUTO_INCREMENT,
            VALUE 
    VARCHAR(20),
            
    PRIMARY KEY (`ID`),
            
    UNIQUE KEY `ID` (`ID`)
        ) ;
        
    WHILE(cur_index<=strlen) DO    
        
    BEGIN
            
    IF SUBSTRING(inputstring FROM cur_index FOR 1)=delim OR cur_index=strlen THEN
                
    SET len=cur_index-last_index-1;
                
    IF cur_index=strlen THEN
                   
    SET len=len+1;
                
    END IF;
                
    INSERT INTO splittable(`value`)VALUES(SUBSTRING(inputstring FROM (last_index+1FOR len));
                
    SET last_index=cur_index;
            
    END IF;
            
    SET cur_index=cur_index+1;
        
    END;
        
    END WHILE;
    END$$

    DELIMITER ;


    CALL proc_split(
    'a,b,c',',');
    SELECT * FROM splittable

    posted on 2011-02-26 21:28 都市淘沙者 閱讀(9531) 評論(0)  編輯  收藏 所屬分類: Oracle/Mysql/Postgres/

    主站蜘蛛池模板: 日韩精品无码免费专区网站| 青青青视频免费观看| 亚洲av永久中文无码精品| 亚洲?V无码乱码国产精品| 国产伦精品一区二区三区免费迷| 日韩一区二区在线免费观看| 亚洲性在线看高清h片| 亚洲国产精彩中文乱码AV| 亚洲国产成人精品无码区在线秒播 | 24小时在线免费视频| 1000部免费啪啪十八未年禁止观看| aa级一级天堂片免费观看| 国产成人免费一区二区三区| 中文字幕免费人成乱码中国| 日韩精品无码一区二区三区免费 | 亚洲成人一级电影| 亚洲国产二区三区久久| 亚洲人成网站999久久久综合| 一级午夜免费视频| 成年女人视频网站免费m| 亚洲永久精品ww47| 亚洲爆乳无码精品AAA片蜜桃| 你懂的免费在线观看| 国产免费看插插插视频| 亚洲国产成人精品久久| 青柠影视在线观看免费高清| 免费h黄肉动漫在线观看| 激情综合亚洲色婷婷五月| 999任你躁在线精品免费不卡| 亚洲成a人片在线观看日本| 国产午夜亚洲精品不卡免下载| 91麻豆最新在线人成免费观看| 黄色成人免费网站| 91久久亚洲国产成人精品性色| 亚洲日韩在线观看免费视频| 国产精品免费看香蕉| 国产尤物在线视精品在亚洲| 黄色网页在线免费观看| 色噜噜噜噜亚洲第一| 成人黄软件网18免费下载成人黄18免费视频| 亚洲av无码片在线播放|