ホームページ > データベース > mysql チュートリアル > MySQL で文字列を区切り文字で区切る方法

MySQL で文字列を区切り文字で区切る方法

PHPz
リリース: 2023-06-01 08:43:17
転載
2071 人が閲覧しました
    #MySQL は文字列を区切り文字で区切ります

    を使用すると、次の関数を使用できます

    SUBSTRING_INDEX( i.final_car_type, ' ', 1 )
    ログイン後にコピー

    • i.final_car_type は区切る必要がある文字列です

    • ’ ’ つまり、文字列をスペースで区切ります

    • 1つまり、スペースの前のすべての文字を取り出します。

    count が正の数の場合、結果は、左から右へ N 番目の区切り文字の左側にあるすべての文字になります。負の数の場合は、右から数えて、N 番目の区切り文字の右側にあるすべてのコンテンツを取得することを意味します。

    #Effect

    カウントが 1 の場合

    • 表と内部データ: 東風風神新 AX7 マッハ バージョン DF 21 (サンルーフ バージョン)

    • 分割後: 東風風神新 AX7 マッハ バージョン

    カウントが -1 の場合

    • 表と内部データ: 東風風神 新型 AX7 マッハ バージョン DF 21 (サンルーフ バージョン) )

    • 分割後: 21 (Skylight バージョン)

    MySQL ストアド プロシージャは区切り文字に従って文字列を分割します

    DELIMITER $$
     
    CREATE DEFINER=`root`@`%` PROCEDURE `proc_split_Id`(in selectIds blob(65535),
    in splitChar varchar(2))
    BEGIN
    set @i=0; 
    CREATE TEMPORARY TABLE if not exists Id_Result_s(Id long NOT NULL);
    truncate table Id_Result_s;
    SET @cnt = 1+(LENGTH(selectIds) - LENGTH(REPLACE(selectIds,splitChar,''))); 
    set @i=1; 
    	start transaction;
        WHILE @i <=@cnt DO          
            SET @result = REPLACE(SUBSTRING(SUBSTRING_INDEX(selectIds, splitChar, @i),
           LENGTH(SUBSTRING_INDEX(selectIds, splitChar, @i -1)) + 1),
           splitChar, &#39;&#39;);  
           INSERT INTO Id_Result_s(Id) VALUES (@result );
    		SET @i = @i + 1;   
        END WHILE;  
    	commit;    
    END
    ログイン後にコピー
    selectIds は分割文字列である必要があり、splitChar は区切り文字です。分割結果は一時テーブル Id_Result_s に保存されます。

    while に挿入文があり、ループに挿入されます。開始トランザクションとコミットを追加します。 while の前後で効率が向上します。

    以上がMySQL で文字列を区切り文字で区切る方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    関連ラベル:
    ソース:yisu.com
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    最新の問題
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート