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

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

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

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

受付中

mysql縦持ちのデータを横持ちに入れ替える方法*追記ありlaravel csv出力方法

sql
sql

総合スコア12

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

4回答

-1評価

1クリップ

2403閲覧

投稿2019/05/03 09:39

編集2022/01/12 10:55

前提・実現したいこと

現在のデータベース

iduser_idname
11サッカー
21野球
31陸上
42野球
52水泳
63テニス
74野球
84陸上

まとめたいデータベース

user_idname1name2name3
1サッカー野球陸上
2野球水泳
3テニス
4野球陸上

発生している問題・エラーメッセージ

[42000][1064] You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(partition by user_id) as seq from sample_table ) tmp group ...

https://dev.classmethod.jp/etc/sql-data-horizontal-vertical/
上記のURLより横にデータを変更する方法を見つけました。

しかし、 ,row_number() over (partition by employee_id) as seqでsyntaxが出ました。
それと上記のURLのものでは横のカラムが固定のもの(qualification_id1~4)になってしまうためそのままでは使用できませんでした。

自分のものではnameのカラムは動的にしたいです。
ユーザーが持っているnameの数だけname(n)のように増やしたいです。

該当のソースコード

mysql

select tmp.user_id, max(case tmp.seq when 1 then tmp.name else null end) as name1, max(case tmp.seq when 2 then tmp.name else null end) as name2, max(case tmp.seq when 3 then tmp.name else null end) as name3, max(case tmp.seq when 4 then tmp.name else null end) as name4 from ( select user_id, name, row_number() over (partition by user_id) as seq from sample_table ) tmp group by tmp.user_id;

放り投げの質問になってしまって申し訳ありませんが、ご教授、ご対応できる方がいましたら急ぎではありませんのでご対応していただけるとありがたいです。よろしくお願いいたします。

###追記(2019/05/04)

userテーブル

idageuser_namezipaddress
110斎藤111-1111東京都サンプル区サンプル1-1-1
211近藤111-1111東京都サンプル区サンプル1-1-1
312大久保111-1111東京都サンプル区サンプル1-1-1
423中田111-1111東京都サンプル区サンプル1-1-1

sampleテーブル

iduser_idname
11サッカー
21野球
31陸上
42野球
52水泳
63テニス
74野球
84陸上

csvでの出力

idageuser_namezipaddressname1name2name3
110斎藤111-1111東京都サンプル区サンプル1-1-1サッカー野球陸上
211近藤111-1111東京都サンプル区サンプル1-1-1野球水泳
312大久保111-1111東京都サンプル区サンプル1-1-1テニス
423中田111-1111東京都サンプル区サンプル1-1-1野球陸上

laravelで上記のようにcsvを出力させたいです。ご教授お願いいたします。

php

//ヘッダーを作成 $headers = ['id', 'age', 'user_name', 'zip', 'address']; foreach ($headers as $header) { $arr[0][] = $header; } //BODYを作成 $items = User::select('*')->get(); foreach ($items as $key => $item) { $arr[$key + 1] = $item; } $fp = fopen('file.csv', 'w'); foreach ($arr as $fields) { fputcsv($fp, $fields); } fclose($fp);

上記で出力されるcsv

idageuser_namezipaddress
110斎藤111-1111東京都サンプル区サンプル1-1-1
211近藤111-1111東京都サンプル区サンプル1-1-1
312大久保111-1111東京都サンプル区サンプル1-1-1
423中田111-1111東京都サンプル区サンプル1-1-1

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。