検索

参考:

query方式:https://github.com/yii2-chinesization/yii2-zh-cn/blob/master/guide-zh-CN/db-query-builder.md

Active Record模式 :https://github.com/yii2-chinesization/yii2-zh-cn/blob/master/guide-zh-CN/db-active-record.md


建立数据库链接

class Customer extends ActiveRecord{    // ...    public static function getDb()    {        return /Yii::$app->db2;  // 使用名为 "db2" 的应用组件  默认是db    }}

声明AR类

namespace app/models;use yii/db/ActiveRecord;class Customer extends ActiveRecord{    /**     * @return string 返回该AR类关联的数据表名     */    public static function tableName()    {        return 'customer';    }}

查询数据

// 取回所有活跃客户(状态为 *active* 的客户)并以他们的 ID 排序:$customers = Customer::find()    ->where(['status' => Customer::STATUS_ACTIVE]) //Customer中定义的常量    ->orderBy('id')    ->all();// 返回ID为1的客户:$customer = Customer::find()    ->where(['id' => 1])    ->one();// 取回活跃客户的数量:$count = Customer::find()    ->where(['status' => Customer::STATUS_ACTIVE])    ->count();// 以客户ID索引结果集:$customers = Customer::find()->indexBy('id')->all();// $customers 数组以 ID 为索引// 用原生 SQL 语句检索客户:$sql = 'SELECT * FROM customer';$customers = Customer::findBySql($sql)->all();

有两个快捷方法:findOne 和 findAll() 用来返回一个或者一组ActiveRecord实例。前者返回第一个匹配到的实例,后者返回所有。 例如:

// 返回 id 为 1 的客户$customer = Customer::findOne(1);// 返回 id 为 1 且状态为 *active* 的客户$customer = Customer::findOne([    'id' => 1,    'status' => Customer::STATUS_ACTIVE,]);// 返回id为1、2、3的一组客户$customers = Customer::findAll([1, 2, 3]);// 返回所有状态为 "deleted" 的客户$customer = Customer::findAll([    'status' => Customer::STATUS_DELETED,]);
数组形式获取数据
// 以数组而不是对象形式取回客户信息:$customers = Customer::find()    ->asArray()    ->all();// $customers 的每个元素都是键值对数组
批量获取数据
// 一次提取 10 个客户信息foreach (Customer::find()->batch(10) as $customers) {    // $customers 是 10 个或更少的客户对象的数组}// 一次提取 10 个客户并一个一个地遍历处理foreach (Customer::find()->each(10) as $customer) {    // $customer 是一个 ”Customer“ 对象}// 贪婪加载模式的批处理查询foreach (Customer::find()->with('orders')->each() as $customer) {}
例子:
// 插入新客户的记录$customer = new Customer();$customer->name = 'James';$customer->email = 'james@example.com';$customer->save();  // 等同于 $customer->insert();// 更新现有客户记录$customer = Customer::findOne($id);$customer->email = 'james@example.com';$customer->save();  // 等同于 $customer->update();// 删除已有客户记录$customer = Customer::findOne($id);$customer->delete();// 删除多个年龄大于20,性别为男(Male)的客户记录Customer::deleteAll('age > :age AND gender = :gender', [':age' => 20, ':gender' => 'M']);// 所有客户的age(年龄)字段加1:Customer::updateAllCounters(['age' => 1]);

查询关联数据

class Customer extends /yii/db/ActiveRecord{    public function getOrders()    {        // 客户和订单通过 Order.customer_id -> id 关联建立一对多关系        return $this->hasMany(Order::className(), ['customer_id' => 'id']);    }}class Order extends /yii/db/ActiveRecord{    // 订单和客户通过 Customer.id -> customer_id 关联建立一对一关系    public function getCustomer()    {        return $this->hasOne(Customer::className(), ['id' => 'customer_id']);    }}
join类型关联查询
// 查找所有订单并以客户 ID 和订单 ID 排序,并贪婪加载 "customer" 表$orders = Order::find()->joinWith('customer')->orderBy('customer.id, order.id')->all();// 查找包括书籍的所有订单,并以 `INNER JOIN` 的连接方式即时加载 "books" 表$orders = Order::find()->innerJoinWith('books')->all();





声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
データ処理と計算にMySQL関数を使用する方法データ処理と計算にMySQL関数を使用する方法Apr 29, 2025 pm 04:21 PM

MySQL関数は、データ処理と計算に使用できます。 1.基本的な使用には、文字列処理、日付計算、数学操作が含まれます。 2。高度な使用法には、複数の関数を組み合わせて複雑な操作を実装することが含まれます。 3.パフォーマンスの最適化では、Where句での機能の使用を回避し、GroupByおよび一時テーブルを使用する必要があります。

MySQLにデータを挿入する効率的な方法MySQLにデータを挿入する効率的な方法Apr 29, 2025 pm 04:18 PM

MySQLでデータを挿入するための効率的な方法には、次のものが含まれます。1。insertInto ...値構文、2。LoadDatainFileコマンドの使用、3。トランザクション処理の使用、4。バッチサイズの調整、5。Insurtignoreまたは挿入の使用...

フィールドをMySQLテーブルに追加および削除する手順フィールドをMySQLテーブルに追加および削除する手順Apr 29, 2025 pm 04:15 PM

MySQLでは、AlterTabletable_nameaddcolumnnew_columnvarchar(255)afterexisting_columnを使用してフィールドを追加し、andtabletable_namedopcolumncolumn_to_dropを使用してフィールドを削除します。フィールドを追加するときは、クエリのパフォーマンスとデータ構造を最適化する場所を指定する必要があります。フィールドを削除する前に、操作が不可逆的であることを確認する必要があります。オンラインDDL、バックアップデータ、テスト環境、および低負荷期間を使用したテーブル構造の変更は、パフォーマンスの最適化とベストプラクティスです。

MySQLクエリの実行計画を分析する方法MySQLクエリの実行計画を分析する方法Apr 29, 2025 pm 04:12 PM

説明コマンドを使用して、MySQLクエリの実行計画を分析します。 1.説明コマンドは、パフォーマンスのボトルネックを見つけるのに役立つクエリの実行計画を表示します。 2。実行計画には、ID、select_type、table、type、baining_keys、key、key_len、ref、行、およびextraなどのフィールドが含まれます。 3。実行計画によると、インデックスを追加し、完全なテーブルスキャンを避け、参加操作の最適化、オーバーレイインデックスの使用により、クエリを最適化できます。

MySQLサブクエリを使用してクエリ効率を向上させる方法MySQLサブクエリを使用してクエリ効率を向上させる方法Apr 29, 2025 pm 04:09 PM

サブクエリは、MySQLクエリの効率を向上させることができます。 1)Subqueryは、データのフィルタリングや集約値の計算など、複雑なクエリロジックを簡素化します。 2)MySQL Optimizerは、サブクエリを操作に参加させてパフォーマンスを向上させることができます。 3)INの代わりに存在することは、複数の行の戻りエラーを回避できます。 4)最適化戦略には、関連するサブ征服の回避、存在の使用、インデックスの最適化、およびサブクエリネスティングの回避が含まれます。

mysqlの文字セットと照合ルールを構成する方法mysqlの文字セットと照合ルールを構成する方法Apr 29, 2025 pm 04:06 PM

MySQLで文字セットと照合を構成する方法は次のとおりです。1。サーバーレベルでの文字セットとコレクションの設定:setNames'utf8 '; setCharacterSetutf8; setCollat​​ion_connection = 'utf8_general_ci'; 2。特定の文字セットと照合を使用するデータベースを作成します:createdatabaseexample_dbcharactersetutf8collat​​eutf8_general_ci; 3.テーブルを作成するときに文字セットとコレクションを指定:createTableExample_table(idint

MySQLをアンインストールし、残留ファイルをクリーンする方法MySQLをアンインストールし、残留ファイルをクリーンする方法Apr 29, 2025 pm 04:03 PM

安全かつ徹底的にMySQLをアンインストールし、すべての残留ファイルをクリーンにするには、次の手順に従ってください。1。MySQLサービスを停止します。 2。MySQLパッケージをアンインストールします。 3.構成ファイルとデータディレクトリのクリーン。 4.アンインストールが徹底していることを確認します。

MySQLのデータベースの名前を変更する方法MySQLのデータベースの名前を変更する方法Apr 29, 2025 pm 04:00 PM

MySQLでデータベースを変更するには、間接的な方法が必要です。手順は次のとおりです。1。新しいデータベースを作成します。 2。mysqldumpを使用して、古いデータベースをエクスポートします。 3.データを新しいデータベースにインポートします。 4.古いデータベースを削除します。

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 Mac版

SublimeText3 Mac版

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

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン