<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 都市淘沙者 閱讀(9537) 評論(0)  編輯  收藏 所屬分類: Oracle/Mysql/Postgres/

    主站蜘蛛池模板: a级毛片免费高清毛片视频| 亚洲最大福利视频| 又黄又大的激情视频在线观看免费视频社区在线 | 立即播放免费毛片一级| 成人免费午夜视频| 一区二区亚洲精品精华液| 在线观看免费人成视频| 精品亚洲成A人无码成A在线观看| 67pao强力打造高清免费| 激情内射亚洲一区二区三区| 久9热免费精品视频在线观看| 亚洲AV无码乱码国产麻豆| 久久精品中文字幕免费| 老司机亚洲精品影院无码| 91九色精品国产免费| 亚洲天堂男人影院| 国产成人免费a在线资源| 免费精品国产自产拍在线观看| 亚洲精品视频在线观看你懂的| 色多多A级毛片免费看| 亚洲精品成人片在线观看精品字幕 | 国产亚洲精品成人AA片| 日本一道综合久久aⅴ免费| 免费高清A级毛片在线播放| 亚洲色无码一区二区三区| 十八禁视频在线观看免费无码无遮挡骂过 | 免费无码一区二区| 亚洲精品无码不卡在线播HE| 无码av免费一区二区三区试看| 亚洲黄色中文字幕| 好男人看视频免费2019中文| 看Aⅴ免费毛片手机播放| 亚洲日韩欧洲乱码AV夜夜摸| www.免费在线观看| 国产午夜亚洲精品午夜鲁丝片| 精品97国产免费人成视频 | 久久亚洲国产午夜精品理论片| 黄色a三级三级三级免费看| 亚洲乱亚洲乱妇无码麻豆| 99久久综合国产精品免费| 四虎影视久久久免费|