###前提・実現したいこと
SQLで一部文字列を抽出する方法はありますか?
例:メールアドレスからの「@」の前を抽出
例:埼玉県、神奈川県、千葉県…等のリストから「県」の前を抽出
初めの○文字等、決まった文字数を一律で抽出する方法はわかるのですが、
上記のような指定文字の前の部分を抽出する方法はありますでしょうか。
恐れ入りますが、どうぞよろしくお願い致します。
###補足情報(言語/FW/ツール等のバージョンなど)
Microsoft SQL Server Management Studioを使用
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答4件
0
ベストアンサー
都道府県の場合だと県を含むとは限らないので こんな感じで
SQL
1SELECT LEFT(都道府県, CASE WHEN CHARINDEX('県', 都道府県) <> 0 THEN CHARINDEX('県', 都道府県) - 1 ELSE 0 END) AS 県名
CHARINDEX の代わりに PATINDEX を使うと後方一致や前方一致も出来ます。
投稿2017/05/22 02:12
総合スコア4152
0
試してませんが、こんな感じでできないでしょうか。
必ず@が含まれている前提ですが。
SQL
1SELECT SUBSTRING(mail,1,CHARINDEX(mail,'@')-1)
NULLと@を含まない場合の対策版
SQL
1SELECT 2 CASE mail 3 WHEN NULL THEN 4 NULL 5 ELSE 6 SUBSTRING(mail,1,CASE CHARINDEX('@',mail) WHEN 0 THEN LEN(mail) ELSE CHARINDEX('@',mail)-1 END) 7 END;
投稿2017/05/22 01:37
編集2017/05/22 05:14総合スコア17000
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/05/22 01:55
2017/05/22 04:52
2017/05/22 04:55
2017/05/22 05:04
2017/05/22 05:15
2017/05/26 05:29
0
Oracleで@が必ずあるのが前提で、
SQL
1SELECT SUBSTR(MAIL_ADDR, 1, INSTR(MAIL_ADDR, '@') -1) FROM 2(SELECT 'abc123@amail.com' AS MAIL_ADDR FROM DUAL) ;
SQLはデータベースによって方言がありますから、お使いのデータベースを明記した方が良いですよ。
投稿2017/05/22 06:59
総合スコア16417
0
mysqlとpostgresではpositionは使える様です
sql
1select substr('hoge@abc.co.jp',1,position('@' in 'hoge@abc.co.jp')-1); 2 3 4select substr('埼玉県ほげほげ市ほげほげ町',1,position('県' in '埼玉県ほげほげ市ほげほげ町')-1);
投稿2017/05/22 02:05
編集2017/05/22 02:09総合スコア4070
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/05/22 05:04