YII2 データベースクエリの練習
この記事では、主に YII2 データベース クエリの実践に関する関連情報を紹介します。必要な方は、
yii2 フレームワークの初期探索、追加、削除、変更、クエリなどの基本的なデータベース操作の簡単な実践を参照してください。クエリ。
データベース構成。
/config/db.php データベースを設定します
演習プロセスでは、テストライブラリ-「テストテーブル-」があり、次の2つのレコードがあります
mysql> select * from test;
+---+ ---- ----+
| 名前 |
+----+------+
|
+----+--------+
18 行セット (0.00 秒)
$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
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();
クエリ操作
// 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));
}
//削除
// 削除を選択
$res = Test::find()->where(['id'=>1])->all();
$res[0]->delete() ;
// 直接削除
var_dump(Test::deleteAll('id>:id', array(':id' => 2)));
$res = Test::find()->where(['id'=>4])->one();
$res->name = "update" ;
$res->save();
$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);
まず、関連する呼び出し関数を 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 プロセス中の追加、削除、変更、関連クエリなどのいくつかの基本操作。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

MySQLは、オープンソースのリレーショナルデータベース管理システムです。 1)データベースとテーブルの作成:createdatabaseおよびcreateTableコマンドを使用します。 2)基本操作:挿入、更新、削除、選択。 3)高度な操作:参加、サブクエリ、トランザクション処理。 4)デバッグスキル:構文、データ型、およびアクセス許可を確認します。 5)最適化の提案:インデックスを使用し、選択*を避け、トランザクションを使用します。

NAVICATでSQLを実行する手順:データベースに接続します。 SQLエディターウィンドウを作成します。 SQLクエリまたはスクリプトを書きます。 [実行]ボタンをクリックして、クエリまたはスクリプトを実行します。結果を表示します(クエリが実行された場合)。

NAVICATがデータベースとそのソリューションに接続できない一般的な理由:1。サーバーの実行ステータスを確認します。 2。接続情報を確認します。 3.ファイアウォール設定を調整します。 4.リモートアクセスを構成します。 5.ネットワークの問題のトラブルシューティング。 6.許可を確認します。 7.バージョンの互換性を確保します。 8。他の可能性のトラブルシューティング。

手順に従って、NAVICATで新しいMySQL接続を作成できます。アプリケーションを開き、新しい接続(CTRL N)を選択します。接続タイプとして「mysql」を選択します。ホスト名/IPアドレス、ポート、ユーザー名、およびパスワードを入力します。 (オプション)Advanced Optionsを構成します。接続を保存して、接続名を入力します。

データベースに接続するときの一般的なエラーとソリューション:ユーザー名またはパスワード(エラー1045)ファイアウォールブロック接続(エラー2003)接続タイムアウト(エラー10060)ソケット接続を使用できません(エラー1042)SSL接続エラー(エラー10055)接続の試みが多すぎると、ホストがブロックされます(エラー1129)データベースは存在しません(エラー1049)

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。
