検索
ホームページPHPフレームワークLaravelthinkphpのクエリ文の詳細な説明

ThinkPHP は、オープンソースの PHP ベースの Web アプリケーション フレームワークで、クエリ ステートメントの構築と実行など、便利な開発のための多くのツールとソリューションを提供します。この記事では、開発者がデータベース操作をより効率的に実行できるように、クエリ ビルダーとデータ モデルを含む ThinkPHP のクエリ ステートメント機能を紹介します。

1. クエリ ビルダー

ThinkPHP のクエリ ビルダーは、複雑な SQL ステートメントを迅速に構築するために使用されるオブジェクト指向 SQL ステートメント ビルダーのセットです。クエリ ビルダーでは、いくつかの方法を使用して、SELECT、UPDATE、INSERT、および DELETE タイプの SQL ステートメントを構築できます。

  1. SELECT クエリ ステートメント

SELECT クエリ ステートメントを使用して、データベース内のデータを取得します。クエリ ビルダーの select() メソッドを使用して、SELECT クエリ ステートメントを構築できます。

// 查询所有用户数据
Db::name('user')->select();

// 查询 id 为 1 的用户数据
Db::name('user')->where('id', 1)->find();

// 查询年龄大于 18 岁的用户数据
Db::name('user')->where('age', '>', 18)->select();

上記のコードでは、 Db::name('user') はクエリ対象のデータ テーブルを表します。 select() メソッドはすべてのデータのクエリを示し、find() メソッドは単一レコードのクエリを示します。

  1. UPDATE クエリ ステートメント

UPDATE クエリ ステートメントを使用して、データベース内のデータを更新します。クエリ ビルダーの update() メソッドを使用して、UPDATE クエリ ステートメントを構築できます。

// 更新 id 为 1 的用户数据
Db::name('user')->where('id', 1)->update(['name' => 'Tom']);

// 将所有用户的角色都更新为 2
Db::name('user')->update(['role_id' => 2]);

update() メソッドでは、最初のパラメータは更新されるレコードの条件を表し、2 番目のパラメータは更新されるレコードの条件を表します。更新データの内容です。

  1. INSERT クエリ ステートメント

INSERT クエリ ステートメントを使用して、新しいデータをデータベースに挿入します。クエリ ビルダーの insert() メソッドを使用して、INSERT クエリ ステートメントを構築できます。

// 向 user 表中插入一条新数据
Db::name('user')->insert(['name' => 'Jack', 'age' => 20, 'role_id' => 1]);

insert() メソッドのパラメータは、挿入される新しいデータ コンテンツです。

  1. DELETE クエリ ステートメント

DELETE クエリ ステートメントを使用して、データベース内のデータを削除します。クエリ ビルダーの delete() メソッドを使用して、DELETE クエリ ステートメントを作成できます。

// 删除 id 为 1 的数据
Db::name('user')->where('id', 1)->delete();

// 删除所有角色为 3 的用户数据
Db::name('user')->where('role_id', 3)->delete();

delete() メソッドのパラメータは、削除されるレコードの条件です。

2. データ モデル

クエリ ビルダーに加えて、ThinkPHP は、データ テーブルをクラスにマッピングできる、データ モデルに基づくデータベース操作メソッドのセットも提供します。クラス属性の変更に基づいてデータベース レコードの CRUD を自動的に処理します。

  1. データ モデルの定義

次のコードを使用してデータ モデル クラスを定義できます:

namespace app\common\model;

use think\Model;

class User extends Model
{
    // 数据表名
    protected $table = 'user';

    // 自动写入时间戳
    protected $autoWriteTimestamp = true;

    // 模型关联:用户角色
    public function role()
    {
        return $this->belongsTo(Role::class, 'role_id');
    }
}

上の例では、 think を継承します。 \Model クラスはユーザー データ モデル クラスを定義します。 $table 属性はマップされるデータ テーブルの名前を示し、$autoWriteTimestamp 属性はタイムスタンプを自動的に書き込むかどうかを示します。

  1. データのクエリ

データ モデルの find()、select()、where() およびその他のメソッドを使用して、データベースにクエリを実行できます。

// 查询 id 为 1 的用户数据
$user = User::find(1);

// 查询用户表中所有数据
$users = User::select();

// 查询年龄大于 18 岁的用户数据
$users = User::where('age', '>', 18)->select();
上記の例では、データ モデル クラスの静的メソッドを使用してデータベース クエリを実行しました。

    データの更新と挿入
データ モデルの save() メソッドを使用して、データの更新と挿入を行うことができます:

// 更新 id 为 1 的用户数据
$user = User::find(1);
$user->name = 'Tom';
$user->save();

// 向 user 表中插入一条新数据
$user = new User;
$user->name = 'Jack';
$user->age = 20;
$user->role_id = 1;
$user->save();
上記ではたとえば、データ モデル オブジェクトのプロパティを使用して、更新または挿入されるデータを設定し、save() メソッドを呼び出してデータベースに送信します。

    データの削除
データ モデルの delete() メソッドを使用してデータを削除できます:

// 删除 id 为 1 的用户数据
$user = User::find(1);
$user->delete();

// 删除所有角色为 3 的用户数据
User::where('role_id', 3)->delete();
上の例では、次のように使用しました。データ モデル オブジェクトの delete() メソッドは、指定されたレコードを削除します。また、静的メソッドの where() メソッドを使用して、削除するレコードを選択し、delete() メソッドを呼び出してそれを削除することもできます。

概要

上記は、ThinkPHP を使用してクエリ ステートメントを構築する方法です。クエリ ビルダーには、SELECT、UPDATE、INSERT、DELETE などの SQL ステートメントとデータ モデルを構築するためのさまざまなメソッドが用意されています。 . データベースを操作するためのオブジェクト指向の方法を提供します。クエリ ビルダーを使用するかデータ モデルを使用するかに関係なく、複雑な SQL クエリ ステートメントを迅速に構築して、開発者がデータベース操作を実行しやすくすることができます。

以上がthinkphpのクエリ文の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Laravelの影響:Web開発の簡素化Laravelの影響:Web開発の簡素化Apr 21, 2025 am 12:18 AM

Laravelは、Web開発プロセスを簡素化し、強力な機能を提供することで際立っています。その利点には、1)簡潔な構文と強力なORMシステム、2)効率的なルーティングと認証システム、3)豊富なサードパーティライブラリサポート。開発者はエレガントなコードの作成に集中し、開発効率を向上させることができます。

Laravel:フロントエンドまたはバックエンド?フレームワークの役割を明確にしますLaravel:フロントエンドまたはバックエンド?フレームワークの役割を明確にしますApr 21, 2025 am 12:17 AM

laravelispredomintylyabackendframework、Designeforerver-sidelogic、databasemanagement、およびapidevelopmentが、BladeTemplatesで開発されたものです。

Laravel vs. Python:パフォーマンスとスケーラビリティの探索Laravel vs. Python:パフォーマンスとスケーラビリティの探索Apr 21, 2025 am 12:16 AM

LaravelとPythonには、パフォーマンスとスケーラビリティの点で独自の利点と短所があります。 Laravelは非同期処理とキューイングシステムを通じてパフォーマンスを向上させますが、PHPの制限により、高い並行性が存在する場合はボトルネックがある場合があります。 Pythonは、非同期フレームワークと強力なライブラリエコシステムでうまく機能しますが、Multi-Threaded環境のGILの影響を受けます。

Laravel vs. Python(フレームワーク付き):比較分析Laravel vs. Python(フレームワーク付き):比較分析Apr 21, 2025 am 12:15 AM

Laravelは、チームがPHPに精通しており、豊富な機能を必要とするプロジェクトに適していますが、Python Frameworksはプロジェクトの要件に依存します。 1.Laravelは、迅速な開発と柔軟性を必要とするプロジェクトに適したエレガントな構文とリッチな機能を提供します。 2。Djangoは、「バッテリー包含」の概念のため、複雑なアプリケーションに適しています。 3.Flaskは、高速プロトタイプや小規模プロジェクトに適しており、柔軟性が非常に高くなります。

LaravelのFrontEnd:可能性の調査LaravelのFrontEnd:可能性の調査Apr 20, 2025 am 12:19 AM

Laravelは、フロントエンド開発に使用できます。 1)ブレードテンプレートエンジンを使用して、HTMLを生成します。 2)Viteを統合して、フロントエンドリソースを管理します。 3)SPA、PWA、または静的Webサイトを構築します。 4)ルーティング、ミドルウェア、Eloquentormを組み合わせて、完全なWebアプリケーションを作成します。

PHPとLaravel:サーバー側のアプリケーションの構築PHPとLaravel:サーバー側のアプリケーションの構築Apr 20, 2025 am 12:17 AM

PHPとLaravelを使用して、効率的なサーバー側アプリケーションを構築できます。 1.PHPは、Web開発に適したオープンソーススクリプト言語です。 2.Laravelは、ルーティング、コントローラー、Eloquentorm、ブレードテンプレートエンジン、および開発を簡素化するためのその他の機能を提供します。 3.キャッシュ、コードの最適化、セキュリティ対策により、アプリケーションのパフォーマンスとセキュリティを改善します。 4.アプリケーションの安定した動作を確保するためのテストおよび展開戦略。

Laravel vs. Python:学習曲線と使いやすさLaravel vs. Python:学習曲線と使いやすさApr 20, 2025 am 12:17 AM

LaravelとPythonには、学習曲線と使いやすさの点で独自の利点と短所があります。 Laravelは、Webアプリケーションの迅速な発展に適しています。学習曲線は比較的フラットですが、高度な機能をマスターするには時間がかかります。 Pythonの文法は簡潔で、学習曲線はフラットですが、動的なタイプのシステムは注意する必要があります。

Laravelの強み:バックエンド開発Laravelの強み:バックエンド開発Apr 20, 2025 am 12:16 AM

バックエンド開発におけるLaravelの利点には、次のものがあります。1)エレガントな構文とEloquentorm開発プロセスを簡素化します。 2)豊富な生態系と積極的なコミュニティサポート。 3)開発効率とコードの品質の向上。 Laravelの設計により、開発者は強力な機能とツールを通じてより効率的に開発し、コードの品質を向上させることができます。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

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

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。