🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
SQL

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

3回答

5658閲覧

SQL文でROW_NUMBER() OVERを使ってデータを取得できない

退会済みユーザー

退会済みユーザー

総合スコア0

SQL

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

1クリップ

投稿2021/03/08 15:02

編集2021/03/13 15:12

##解決したいこと
SELECT ROW_NUMBER()OVERを使って、データを取得したいが、以下のコードを実行するとエラーが出る。

$sql = 'SELECT ROW_NUMBER() OVER(ORDER BY p.kickoff ASC) as "点数", p.kickoff as "試合日時", c.name as "対戦相手", g.goal_time as "ゴールタイム" FROM pairings as p LEFT JOIN countries as c ON p.enemy_country_id = c.id LEFT JOIN goals as g ON g.pairing_id = p.id WHERE g.player_id = :id'; $sth = $this->dbh->prepare($sql); $sth->bindValue(':id', $id, PDO::PARAM_INT); $sth->execute(); $result = $sth->fetchAll(PDO::FETCH_ASSOC); return $result;

##該当エラー

SELECT ROW_NUMBER() OVER(ORDER BY p.kickoff ASC) as "点数", p.kickoff as "試合日時", c.name as "対戦相手", g.goal_time as "ゴールタイム"

イメージ説明

イメージ説明
SQLを実行してみたところ、エイリアスエラーなどが表示される。

#1064 - SQL構文エラーです。バージョンに対応するマニュアルを参照して正しい構文を確認してください。 : '(ORDER BY p.kickoff ASC) as "点数", p.kickoff as "試合日時", c.name as "' 付近 1 行目
など

mysqlのバージョンは5.7です。

##試したこと
・データベースの接続に問題はないか?
→問題ない。一覧取得や他の詳細データを取得できる。

・SELECT文の中身を変更したら、データは取得できるか?
→できる。例: SELECT * FROM playersなどを実行してみた。

ROW_NUMBERの使い方とか調べましたが、自分では解決できず困っています。

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

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

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

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

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

guest

回答3

0

SQL

1$sql = 'SELECT * FROM players WHERE id = :id'

上記で上手くいったと言っても、質問のSQLではplayersは全然関係ないですからね。

確認するなら以下でしょうけど、そもそも:IDがpairingsに対するものなのかは不明ですが。

SQL

1$sql = 'SELECT * FROM pairings WHERE id = :id'

追記

エイリアスや項目を"で括ってはいけません。 ←"で括っても大丈夫でした。5.7での確認では無いですが。

SQL

1SELECT ROW_NUMBER() OVER(ORDER BY p.kickoff ASC) as 点数, p.kickoff as 試合日時, c.name as 対戦相手, g.goal_time as ゴールタイム

上記で駄目な場合は、「`」で括って下さい。

投稿2021/03/09 00:39

編集2021/03/14 06:17
sazi

総合スコア25327

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

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

退会済みユーザー

退会済みユーザー

2021/03/14 02:24

ご回答ありがとうございます。 ""を外したり、``でくくったりしましたが、解決できませんでした。
sazi

2021/03/14 06:00

コマンドなどで実行してエラーにならないSQLをプログラムに実装するのが基本です。 コマンドやDBツールなどで確認して下さい。
sazi

2021/03/14 06:19 編集

バージョンは5.7ですか。 であれば、row_number()は使えません。 window関数が使用できるのは8.0からです。
guest

0

  • 単に合致するレコードがないか
  • SQL文が実はまちがっていてエラーを返しているけどPDOが例外処理をしていないか

ではないでしょうか?

投稿2021/03/09 00:58

yambejp

総合スコア116661

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

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

退会済みユーザー

退会済みユーザー

2021/03/09 13:25

レコードが合致するか検証したところ、上記のようにSQL構文エラーが表示されました。例外処理は一応実装しています。
yambejp

2021/03/10 00:09

SQLのバージョンはなんでしょう? あまり関係ないかもしれませんが エイリアスのエンクロージャをダブルクォーテーションから バッククォーテーションに変えてみてください ("→`)
退会済みユーザー

退会済みユーザー

2021/03/10 14:18

phpmyadminのバージョンは4.9.7です。バッククォーテーションに変更してもエラーは解決しなかったです。
yambejp

2021/03/11 00:09 編集

>phpmyadminのバージョン いえMySQLのバージョンです phpMyAdminだとTOPページにサーバのバージョンが表示されると思います
退会済みユーザー

退会済みユーザー

2021/03/11 12:50

失礼いたしました。5.7.32です。
guest

0

ベストアンサー

追記
なんか全く使った覚えが無いのでまず動作確認をすすめたのだけれど…仕様になかったらしい。

MySQLではROW_NUMBERが使えない

MySQLでは ROW_NUBER関数が使えません。
ROW_NUMBER関数と同じことをMySQLで実装する場合は「ユーザ変数」を使用します。
※ポテパンから抜粋

参考URL ポテパン【SQL】連番を振る
https://style.potepan.com/articles/23566.html

8系から使えるようになったとかなんとか。

MySQL でも 8.0 から Window 関数が使えるようになりましたが

※Qiitaから抜粋

参考URL Qiita MySQL の Window 関数を完全に理解する
https://qiita.com/ngyuki/items/c35dd314815939ffbeb6


あまり得意ではないのだけども…
まず最小構成でテーブルの結合等も行わず、
asも使わずにSQL文が通るかどうか試してみるのはいかがでしょうか。

SQL

1SELECT ROW_NUMBER() OVER(ORDER BY p.kickoff ASC) score, 2FROM pairings

みたいな。テーブル1つ、カラム1つ。※カラムは複数あった方が良いかもしれない。

投稿2021/03/14 05:50

編集2021/03/14 06:21
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問