ホームページ バックエンド開発 PHPチュートリアル CakePHP でデータをクエリおよび更新するにはどうすればよいですか?

CakePHP でデータをクエリおよび更新するにはどうすればよいですか?

Jun 03, 2023 pm 02:11 PM
更新する cakephp データクエリ

CakePHP は、便利な ORM (オブジェクト リレーショナル マッピング) 機能を提供する人気の PHP フレームワークで、データベースのクエリと更新を非常に簡単にします。

この記事では、CakePHP でデータをクエリおよび更新する方法を紹介します。単純なクエリと更新から始めて、条件と関連モデルを使用してより複雑なデータのクエリと更新を行う方法を見ていきます。

  1. 基本的なクエリ

まず、最も単純なクエリの作成方法を見てみましょう。 「Users」というデータ テーブルがあり、すべてのユーザー レコードを取得したいとします。

CakePHP では、find メソッドを使用してデータを取得できます。サンプル コードは次のとおりです。

$users = $this->Users->find('all');
ログイン後にコピー

これは、すべてのユーザー レコードを含む配列を返します。 1 つのレコードだけを取得したい場合は、find('first') メソッドを使用できます。

$user = $this->Users->find('first');
ログイン後にコピー

これにより、最初のユーザー レコードが返されます。 find('list') メソッドを使用して、キーと値のペアのハッシュ テーブルを取得することもできます。ここで、キーはレコードの主キーであり、値は指定されたフィールドです。たとえば、ユーザー ID と名前のハッシュ テーブルを取得したい場合は、次のコードを使用できます。

$users = $this->Users->find('list', ['keyField' => 'id', 'valueField' => 'name']);
ログイン後にコピー
  1. 条件付きクエリ

実行する必要がある場合条件付きクエリ CakePHP は、クエリ結果のデータをフィルタリングする便利な方法を提供します。 where メソッドと andWhere メソッドを使用して、プログラムでクエリ条件を作成できます。以下はサンプル コードです。

$users = $this->Users->find()
    ->where(['age >' => 18, 'name LIKE' => '%John%'])
    ->andWhere(['gender' => 'male'])
    ->all();
ログイン後にコピー

上記のコードでは、where メソッドと andWhere メソッドを使用してクエリ条件を指定します。最初の条件は、18 歳以上で名前に「John」が含まれるユーザーを指定します。 2 番目の条件は、性別が「男性」のユーザーを指定します。最後に、all メソッドを使用して、条件を満たすすべてのユーザー レコードを取得します。

IN、NOT IN、BETWEEN などの複雑なクエリ条件を使用することもできます。サンプル コードは次のとおりです。

$users = $this->Users->find()
    ->where(['age BETWEEN' => [18, 25]])
    ->andWhere(['state IN' => ['CA', 'NY', 'TX']])
    ->all();
ログイン後にコピー

上記のコードでは、BETWEEN 条件と IN 条件を使用して、18 ~ 25 歳でステータスが CA、NY、または TX のユーザーを指定しました。同様に、all メソッドを使用して、基準を満たすすべてのユーザー レコードを取得します。

  1. 相関クエリ

CakePHP では、相関クエリを簡単に実行できます。ユーザー レコードに加えて「投稿」というデータ テーブルがあり、各ユーザーが複数の投稿を持っているとします。ユーザーとそのすべての投稿をクエリする方法を見てみましょう。

まず、User モデルで Posts の関連付けを定義する必要があります。 belongsTo メソッドを使用して、データ テーブルを User モデルに関連付けることができます。以下はサンプル コードです:

class UsersTable extends Table
{
    public function initialize(array $config)
    {
        $this->hasMany('Posts');
    }
}
ログイン後にコピー

上記のコードでは、hasMany メソッドを使用して、User モデルと Posts データ テーブルの間の関連付けを指定します。

これで、関連付けられたクエリの find メソッドを使用して、すべてのユーザーとそのすべての記事を取得できるようになります。以下にサンプル コードを示します。

$users = $this->Users->find('all', [
    'contain' => ['Posts']
]);
ログイン後にコピー

上記のコードでは、contain オプションを使用して、関連付けるデータ テーブルを指定します。配列を介して複数の関連付けを指定することもできます。たとえば、User モデルが Comments テーブルにも関連付けられている場合、次のように書くことができます:

$users = $this->Users->find('all', [
    'contain' => ['Posts', 'Comments']
]);
ログイン後にコピー

関連付けられたクエリを実行するとき、CakePHP は内部結合 (INNER JOIN) を使用して 2 つのデータ テーブルを結合して取得します。関連データ。 LEFT JOIN または RIGHT JOIN を使用する場合は、関連付け定義でそれらを指定できます。

  1. データ更新

データベース内のレコードを更新する必要がある場合、CakePHP は更新操作を実行する便利な方法を提供します。 updateAll メソッドを使用して、プログラムによってレコードを更新できます。以下はサンプル コードです。

$result = $this->Users->updateAll(
    ['age' => 25],
    ['name LIKE' => '%John%']
);
ログイン後にコピー

上記のコードでは、updateAll メソッドを使用して、名前に「John」が含まれる 25 歳のすべてのユーザーを更新します。 updateAll メソッドは 2 つのパラメーターを受け入れます。最初のパラメータは、設定する列と値を指定します。上の例では、年齢を 25 に設定しています。 2 番目のパラメータは、レコードを更新する条件を指定します。

1 つのレコードのみを更新する場合は、save メソッドを使用できます。以下はサンプル コードです:

$user = $this->Users->get(1);
$user->age = 25;
$this->Users->save($user);
ログイン後にコピー

上記のコードでは、get メソッドを使用して ID 1 のユーザー レコードを取得します。次に、レコードの経過時間を更新し、save メソッドを使用して変更を保存します。

レコードを削除する必要がある場合は、CakePHP が提供する deleteAll および delete メソッドを使用することもできます。

概要

この記事では、CakePHP でデータのクエリと更新を実行する方法を紹介しました。単純なクエリと更新メソッドの使用方法と、より複雑なクエリと更新に条件付きモデルとリレーショナル モデルを使用する方法を学びました。 CakePHP が提供する便利な ORM 機能を使用すると、アプリケーションのニーズに合わせてデータベースを簡単に操作できます。

以上がCakePHP でデータをクエリおよび更新するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Blizzard Battle.net アップデートが 45% で止まってしまう問題を修正するにはどうすればよいですか? Blizzard Battle.net アップデートが 45% で止まってしまう問題を修正するにはどうすればよいですか? Mar 16, 2024 pm 06:52 PM

Blizzard Battle.net のアップデートが 45% で止まってしまいます。解決するにはどうすればよいですか?最近、ソフトウェア更新時にプログレスバーが 45% で止まってしまうことが多く、何度再起動しても進まないことがありますが、この状況を解決するにはどうすればよいでしょうか? クライアントの再インストール、リージョンの切り替え、ファイルの削除などが考えられます。このソフトウェアチュートリアルでは、より多くの人に役立つことを願って、操作手順を共有します。 Blizzard Battle.net のアップデートが 45% で止まってしまいます、どうすれば解決しますか? 1. クライアント 1. まず、クライアントが公式 Web サイトからダウンロードされた正式バージョンであることを確認する必要があります。 2. そうでない場合、ユーザーはアジアのサーバー Web サイトにアクセスしてダウンロードできます。 3. 入力後、右上隅の「ダウンロード」をクリックします。注: インストール時に簡体字中国語を選択しないようにしてください。

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

エピックセブンの2月22日のアップデート:ミラクルメイドキングダムの第2週目が始まります エピックセブンの2月22日のアップデート:ミラクルメイドキングダムの第2週目が始まります Feb 21, 2024 pm 05:52 PM

エピックセブンは、2月22日正午にノンストップでアップデートされることが確認されました。このアップデートでは、レイアの限定召喚率の増加やスイートミラクル、謎のアップデートなど、多くの新しいアクティビティやコンテンツが追加されます。カードプール、スペシャルサイドストーリー「ミラクルメイドキングダム」の2週目が始まりましたので、今回のアップデートを紹介していきます。モバイルゲーム更新スケジュール: セブンスエピックは2月22日更新: ミラクルメイドキングダム第2週オープン ※「レイア」「スイートミラクル」の限定召喚確率がアップ! ■限定召喚チャンスアップ時間: ~2024/02/22(木) 11:00 ~ 2024/03/07(木) 10:59 ■キャラクター属性と職業: 自然属性、戦士 ■キャラクター紹介: 4人組バンド・ザ「ミラクルメイドキングダム」のサブボーカル、ベイさん

Ubuntu 24.04 に Angular をインストールする方法 Ubuntu 24.04 に Angular をインストールする方法 Mar 23, 2024 pm 12:20 PM

Angular.js は、動的アプリケーションを作成するための無料でアクセスできる JavaScript プラットフォームです。 HTML の構文をテンプレート言語として拡張することで、アプリケーションのさまざまな側面を迅速かつ明確に表現できます。 Angular.js は、コードの作成、更新、テストに役立つさまざまなツールを提供します。さらに、ルーティングやフォーム管理などの多くの機能も提供します。このガイドでは、Ubuntu24 に Angular をインストールする方法について説明します。まず、Node.js をインストールする必要があります。 Node.js は、ChromeV8 エンジンに基づく JavaScript 実行環境で、サーバー側で JavaScript コードを実行できます。ウブにいるために

ランタンとダンジョン2月29日更新:リマスター版╳「ネザの伝説」連携 ランタンとダンジョン2月29日更新:リマスター版╳「ネザの伝説」連携 Feb 28, 2024 am 08:13 AM

「Lantern and Dungeons」は2月29日にアップデートされることが決定しており、アップデート後は「Lantern and Dungeons」のリマスター版が発売され、「ネザの伝説」との連動も予定されている。職業を変更したり、プレイヤーが直接ジョブチェンジしたり、ダンジョンコンテンツも拡張されたり、新たなダンジョンエリアがオープンしたりする予定です。モバイルゲーム更新スケジュール ランタンとダンジョンは2月29日更新:リマスター版╳「ネザの伝説」連動版キーコンテンツ 新しい職業、なぜ転職に誘われるの? 点灯夫って実は転職できるの? こんなカッコいい装備は本当に人を欲張りにする転職後はランタン持ちもカッコいいスキルをたくさん覚えられるそうですよ ゴローさんは「タイパンツは熱い!」と叫んだ。ネザの伝説が集結!天地の輪を手にホットホイールを踏みます♫~知恵と勇気を兼ね備えた小さな英雄、ネザと小さなドラゴンガールがやって来ます

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

Windows は指定されたデバイス、パス、またはファイルにアクセスできません Windows は指定されたデバイス、パス、またはファイルにアクセスできません Jun 18, 2024 pm 04:49 PM

友人のコンピュータにはこのような障害があり、「この PC」と C ドライブのファイルを開くと、「Explorer.EXE Windows は指定されたデバイス、パス、またはファイルにアクセスできません。プロジェクトにアクセスするための適切な権限がない可能性があります。」と表示されます。フォルダ、ファイル、このコンピュータ、ごみ箱などを含め、ダブルクリックするとこのようなウィンドウが表示されますが、通常は右クリックで開きます。システムのアップデートが原因でこの状況が発生した場合は、以下のエディターで解決方法を説明します。 1. レジストリ エディターを開いて Win+R と入力し、「regedit」と入力するか、スタート メニューを右クリックして実行し、「regedit」と入力します。 2. レジストリ「Computer\HKEY_CLASSES_ROOT\PackagedCom\ClassInd」を見つけます。

See all articles