質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

2回答

8118閲覧

【MySQL】後ろから拾うSUBSTRING

tajix_japan

総合スコア132

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

0クリップ

投稿2017/06/01 13:18

下記のようなデータ(カラム数2) があります。

div sub
1 スケジュール(体育)part2 (13)
2 スケジュール社会part1 (23)
3 スケジュール(理科3)part3 (53)
4 スケジュール算数part3 (25)
5 スケジュール国語part4 (20)

上記のsubに記載されている最後のカッコ内の数字を抽出したいというのが趣旨です。

mysql

1 2SELECT 3TRIM(SUBSTRING(sub, LOCATE('(',sub)+1, LOCATE(')',sub)- LOCATE('(',sub)-1)) AS number 4FROM table 5

とすると、社会、算数、国語は23 25 20 を拾いますが、体育、理科は 体育 理科3という最初に()に括られた文字を拾ってきてしまいます。

拾いたい(数字)は必ず最後にありますので、後ろから数えて最初の()を拾うという方法がいいのだと思いますが、知恵がありません。

ご教示戴きたくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

sql

1SELECT REPLACE(SUBSTRING_INDEX(sub, '(', -1), ')', '') AS number FROM `table`;

https://dev.mysql.com/doc/refman/5.6/ja/string-functions.html#function_substring-index

文字列 str から、区切り文字 delim が count 回出現する前の部分文字列を返します。

(中略)
count が負の値の場合は、(右から数えて) 最後の区切り文字の右側にあるすべてが返されます。

実行結果
http://sqlfiddle.com/#!9/4268a7/4


ただし、最も良い方法はカラムを追加し、以下のようなデータ構造にすることです。

divsubnumber
1スケジュール(体育)part213
2スケジュール社会part123
3スケジュール(理科3)part353
4スケジュール算数part325
5スケジュール国語part420

今からテーブル定義を変更できないか、検討してみてください。

投稿2017/06/01 13:44

KiyoshiMotoki

総合スコア4791

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tajix_japan

2017/06/01 14:06

有難うございます。出来ました。 助かりました。 また、アドバイスいただきました件も検討させていただきます。 有難うございました。深く御礼申し上げます。
guest

0

そもそもがSQLとしてやるような構文ではなさそうですが

select `div`,substr(`sub`,-3,2) as point from tbl where `sub` regexp '\\([0-9]{2}\\)$'

のように後ろから3文字目から2文字抜き出してはどうでしょうか?
pointが1桁だったり3桁だったりする可能性があるなら
場合分けが必要ですが・・・

投稿2017/06/01 13:39

yambejp

総合スコア114779

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tajix_japan

2017/06/01 14:07

1桁から4桁まであるのですが、下記で抽出できました。 ひとつ勉強になりました。 本当にありがとうございました。 select `div`,sub,substr(`sub`,-2,1) as point from title_all where `sub` regexp '\\([0-9]{1}\\)$' select `div`,sub,substr(`sub`,-3,2) as point from title_all where `sub` regexp '\\([0-9]{2}\\)$' select `div`,sub,substr(`sub`,-4,3) as point from title_all where `sub` regexp '\\([0-9]{3}\\)$' select `div`,sub,substr(`sub`,-5,4) as point from title_all where `sub` regexp '\\([0-9]{4}\\)$'
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問