ホームページ  >  記事  >  バックエンド開発  >  YII2 データベースクエリの練習

YII2 データベースクエリの練習

PHP中文网
PHP中文网オリジナル
2016-08-04 09:20:091329ブラウズ

この記事では、主に YII2 データベース クエリの実践に関する関連情報を紹介します。必要な方は、

yii2 フレームワークの初期探索、追加、削除、変更、クエリなどの基本的なデータベース操作の簡単な実践を参照してください。クエリ。

データベース構成。

/config/db.php データベースを設定します

演習プロセスでは、テストライブラリ-「テストテーブル-」があり、次の2つのレコードがあります

mysql> select * from test;
+---+ ---- ----+
| 名前 |
+----+------+
|
+----+--------+
18 行セット (0.00 秒)

SQL クエリ メソッド

yii2 は、プレースホルダーを通じて元のデータベース クエリ メソッド findBySql を同時に提供します。このメソッドは、基本的な SQL インジェクション防御を自動的に実行します。コード

// 最も基本的なクエリメソッド

$sql = "select * from test where 1";
$res = Test::findBySql($sql)->all();
var_dump(count($res ) ); // res->2
// findbysql は SQL インジェクションを防ぎます
$id = '1 or 1=1';
$sql = "select * from test where id = " . $id;
$res = Test::findBySql($sql)- > ;all();
var_dump(count($res)); // res-> 2
$sql = "select * from test where id = :id";
// ロケーターは SQL インジェクションを自動的に防止します
$ res = Test::findBySql($sql,array(":id"=>$id))->all();
var_dump(count($res)); // res->1

activeRecord クエリ メソッド

元の SQL メソッドに加えて、各フレームワークは対応するカプセル化されたクエリ メソッドを提供します。これは yii2 にも当てはまります。

モデル

yiiの基本的な作成方法は以下の通りです。コードについては、以下では詳しく説明しません。

namespace appmodels;
use Yii;
use yiidbActiveRecord;
class Test extends ActiveRecord
{
// オプションの対応するテーブル: デフォルトのクラス名とテーブル名が一致する場合、この関数は必要ありません
public static function tableName ()
{
return 'test';
}
// オプション、バリデータ: 主に各フィールドの検証に使用されます
public function rules(){
return [
['id', 'integer'],
['name', 'string', 'length' => [0, 100]],
];
}
}

使用する際はモデルを導入する必要があります

use appmodelsTest;

操作を追加
// add Operation
$test = new Test();
$test->name = 'test';
// 合法性検証
$test->validate();
if($test->hasErrors() ) {
echo "Illegal data";
die;
}
$test->save();

クエリ操作

クエリ操作は、まず公式ドキュメント

activeRecord doc

に移動します。doc

必要な場所重要なことは、Yii クエリは、コード内のバッチクエリ処理など、豊富なライブラリを多数提供しているということです。詳細については、ドキュメントを参照してください。

// select

// id = 1
$res = Test::find()->where(['id' => 1])->all();
var_dump(count($res) )); //1
// id > 0
$res = Test::find()->where(['>','id',0])->all();
var_dump (count($res)); //2
// id > =1 id $res = Test::find()->where(['between','id',1, 2])->all();
var_dump(count($res)); //2
// 名前フィールド like
$res = Test::find()->where(['like', ' name', 'cuihuan'])->all();
var_dump(count($res)); //2
// クエリの使用方法 obj->array
$res = Test::find()- > ;where(['between','id',1,2])->asArray()->all();
var_dump($res[0]['id']); //2
/ / バッチ クエリ、大量のメモリ操作のバッチ クエリの場合
foreach (Test::find()->batch(1) as $test) {
var_dump(count($test));
}

delete オペレーション

//削除

// 削除を選択
$res = Test::find()->where(['id'=>1])->all();
$res[0]->delete() ;
// 直接削除
var_dump(Test::deleteAll('id>:id', array(':id' => 2)));

変更操作

code メソッドに加えて、yii2更新操作を直接提供します。

// アクティビティ記録の変更

$res = Test::find()->where(['id'=>4])->one();
$res->name = "update" ;
$res->save();

関連付けられたクエリ操作

関連付けられたクエリの例の 2 つのテーブル:

学生テーブル (student): id、name;

スコア テーブル (score): id ,stu_id,score

// 対応する生徒のすべてのスコア

$stu = Student::find()->where(['name'=>'xiaozhuai'])->one();
var_dump ( $stu->id);
//基本的には
$scores_1 = $stu->hasMany('appmodelScore',['stu_id'=>$stu->id])->asArray() を取得します- >all();
$scores_2 = $stu->hasMany(Score::className(),['stu_id'=>'id'])->asArray()->all();
var_dump($scores_1);
var_dump($scores_2);

2 つの関連するクエリ メソッド; ただし、コントローラーで関連する操作を実行する場合、コードが非常に複雑になるため、呼び出しはモデルにカプセル化されます

まず、関連する呼び出し関数を Student モデルにカプセル化します

namespace appmodels;
Yii を使用する;
yiidbActiveRecord を使用する;
class Student extends ActiveRecord
{
public static function tableName()
{
return 'student ' ;
}
//スコア情報を取得します
public function getScores()
{
$scores = $this->hasMany(Score::className(), ['stu_id' => 'id'])-> ; asArray()->all();
return $scores;
}
}

その後、2 つの呼び出しメソッドを直接呼び出します

//関数のカプセル化後に呼び出します
$scores = $stu->getScores( ) ;
var_dump($scores);
//__get
$scores = $stu->scores;
var_dump($scores);

の自動呼び出しメソッドを使用します。最後に

上記のデプロイと使用yii2 プロセス中の追加、削除、変更、関連クエリなどのいくつかの基本操作。

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