+-------------------------------+
| SHOP_CD |
+-------------------------------+
| 11230 |
| 11230,21002,28003,28005,99309 |
| 11230,23003 |
| 11230,23003,23003 |
| 11230,28003 |
| 11230,28003,28005 |
| 11230,28005,21002,28003 |
| 11302 |
| 11302,11230 |
| 11302,11230,11332 |
+-------------------------------+
カンマ区切りの文字列を
重複を省いて取得したいと考えておりますが
実現方法が思いつきません
結果としては、
11230
11302
11332
21002
23003
28003
28005
・
・
とSQLのみを使って配列で取得したいと考えております
splitのようなSQL系関数を探したがないので
実現方法またはヒントをいただけると幸いです
宜しく御願いいたします
環境は
PHP5、MySQL5.6
になります
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
#1ですが、参考までに・・・
今回のデータが仮にshopとcdの組み合わせのデータだったとして
shopのマスター、cdのマスター、shopとcdの組み合わせデータの3テーブルが必要です。
以下サンプルです。
//shopマスター
create table master_shop(sid int not null primary key,sname varchar(30));
insert into master_shop values(1,'shop_a'),(2,'shop_b'),(3,'shop_c'),(4,'shop_d'),(5,'shop_e'),(6,'shop_f'),(7,'shop_g'),(8,'shop_h'),(9,'shop_i'),(10,'shop_j');
select * from master_shop;
//cdマスター
create table master_cd(cid int not null primary key,cnumber int unique ,cname varchar(30) unique);
insert into master_cd values(1,11230,'cd_A'),(2,21002,'cd_B'),(3,28003,'cd_C'),(4,28005,'cd_D'),(5,99309,'cd_E'),(6,23003,'cd_F'),(7,11302,'cd_G'),(8,11332,'cd_H');
select * from master_cd;
//shop-cdデータ
create table data_shop_cd(scid int not null primary key auto_increment,sid int,cid int);
insert into data_shop_cd(sid,cid) values(1,1),(2,1),(2,2),(2,3),(2,4),(2,5),(3,1),(3,6),(4,1),(4,6),(4,6),(5,1),(5,3),(6,1),(6,3),(6,4),(7,1),(7,4),(7,2),(7,3),(8,7),(9,7),(9,1),(10,7),(10,1),(10,8)
select * from data_shop_cd;
//集計表
select sc.sid,s.sname,group_concat(c.cnumber order by sc.scid) as SHOP_CD from data_shop_cd as sc
inner join master_shop as s on s.sid=sc.sid
inner join master_cd as c on c.cid=sc.cid
group by sid;
//質問者さん得たいデータはcnumberの昇順のcdマスターデータなので
select * from master_cd order by cnumber asc;
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
ハマっている「お菓子」を教えて!
この世には、おいしいお菓子がありすぎて……。 次何を食べたらいいか迷っています。 みなさんが今、ハマっている「お菓子」を教えてください!
-
【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
2024年は「名探偵コナン30周年」「涼宮ハルヒ20周年」などを迎えますが、 あなたが「もうそんなに!?」と驚いた○○周年を教えてください。
-
CDの保有枚数を教えてください
ひとむかし前はCDを買ったり借りたりが主流でしたが、サブスクで簡単に音楽が聴ける今、CDを手に取ることも減ってきたかと思います。皆さんは2024年現在、何枚くらいCDをお持ちですか?
-
昨日見た夢を教えて下さい
たまにすごいドラマチックな夢見ること、ありませんか? 起きてからも妙に記憶に残っているような、そんな夢。
-
架空の映画のネタバレレビュー
映画のCMを見ていると、やたら感動している人が興奮で感想を話していますよね。 思わずストーリーが気になってしまう架空の感動レビューを教えて下さい!
-
Oracle 8i コンマ(,)を含むデータをinsertしたい
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
全角文字を含む行を検索
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
VIEWの元のテーブルのindexって...
-
Mysql でレコードを追加した時...
-
mysqlのdeleteのサブクエリーで...
-
SQL Left Join で重複を排除す...
-
NOT NULL 制約の削除
-
フォームで 保存ボタンを押して...
-
クエリ表示と、ADOで抽出したレ...
-
引数について
-
エラー 1068 (42000): 複数の主...
-
チェックしてますか?
-
横浜駅周辺でプルコギが食べら...
-
LEFT JOIN と GROUP BY
-
VMware Player でCD-ROMドライ...
-
PL/SQLの変数について
-
mysqlのload data infileで連番...
-
入力値と外部キーをINSERTするには
-
SQLサーバから、項目の属性(型...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
マイクラPC版のコマンドで効率...
-
SQL Left Join で重複を排除す...
-
エラー 1068 (42000): 複数の主...
-
select文のwhere句に配列を入れ...
-
バインド変数について
-
SQLにて特定の文字を除いた検索...
-
Access パラメータクエリをcsv...
-
WordpressのContact form 7でzi...
-
PL/SQLの変数について
-
1テーブル&複数レコードの更新...
-
ある条件の最大値+1を初番する...
-
Updateの複数テーブル条件時のL...
-
sqlで、600行あるテーブルを100...
-
”photo id” とは何ぞや?
-
クエリ表示と、ADOで抽出したレ...
おすすめ情報