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

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

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

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

PHP

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

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

2回答

3289閲覧

CakePHP 3でのDBクエリの発行がよく分からない

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

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

PHP

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

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2016/09/16 05:21

いつもお世話になっております。
今回、CakePHP 3を使っているのですが、クエリの発行に関してわからないことがあります。

1SQLを直接書くことはできない?
今回ややこしいSQLを発行しようとしていまして、下記になります。

SQL

1SELECT MIN(seq + 1) AS gap 2 FROM SeqTbl 3 WHERE (seq+ 1) NOT IN (SELECT seq FROM SeqTbl);

MySQLで連番の歯抜けを取得する - Qiitaから引用させていただきました。

このようなSQLをクエリビルダで書く方法がわからないため、SQLを直接使いたいと思ったのですが
調べてもCakePHP 2や1の記事ばかり出てきます。

CakePHP 3ではできないのでしょうか?
ご回答よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

Cakephp3でも可能です。

php

1$row = $this->Table->connection()->query("select ...")->fetch('assoc');

※Controllerから実行する場合です。Tableは実際のテーブルクラスに変えてください。
Tableクラスから実行する場合は$this->connection()->query()となります。

マニュアルも参照

投稿2016/09/16 05:47

編集2016/09/16 05:51
popobot

総合スコア6586

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

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

退会済みユーザー

退会済みユーザー

2016/09/16 05:52

出来ました!ありがとうございます! コントローラーから$this->Table...の形で行けました!
guest

0

テーブル名やカラム名などテーブル構成があっていれば
そのSQLを発行すれば最初の歯抜けIDは拾えるはずです

ただしSQLを使用するかぎり歯抜けなんて気にする必要はありません。

投稿2016/09/16 05:38

yambejp

総合スコア114572

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

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

退会済みユーザー

退会済みユーザー

2016/09/16 05:54

ご回答ありがとうございます、解決いたしました! 後学のために、歯抜けなんて気にする必要はないのはどういう意味なのか教えていただけますでしょうか?
yambejp

2016/09/16 06:03

> 歯抜けなんて気にする必要はない 今回の例であればseqカラムは連番であることが重要なのではなく ユニークであることが重要です。 つまりユニークであればそのレコードにconstにアクセスできます なので抜け番号があっても誰も困りません。 別の考え方をすると、運用方法によっては抜け番号は発生しません。 きちんとしたSQLの管理ではレコードの削除は行わず、削除フラグを つけて管理します。 その場合seqと削除フラグを複合ユニーク属性をつけます。 削除フラグが0のものだけ表示すれば生きているデータとなります なおどうしても連番で表示する必要ができたときは 特定のルールでソート後、データをインクリメントしながら連番表示するか ランク付けのSQLを利用して連番を獲ればよいでしょう
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問