この記事では、主に 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 プロセス中の追加、削除、変更、関連クエリなどのいくつかの基本操作。

PHPは、現代のWeb開発、特にコンテンツ管理とeコマースプラットフォームで依然として重要です。 1)PHPには、LaravelやSymfonyなどの豊富なエコシステムと強力なフレームワークサポートがあります。 2)パフォーマンスの最適化は、Opcacheとnginxを通じて達成できます。 3)PHP8.0は、パフォーマンスを改善するためにJITコンパイラを導入します。 4)クラウドネイティブアプリケーションは、DockerおよびKubernetesを介して展開され、柔軟性とスケーラビリティを向上させます。

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHPとPythonにはそれぞれ独自の利点があり、さまざまなシナリオに適しています。 1.PHPはWeb開発に適しており、組み込みのWebサーバーとRich Functionライブラリを提供します。 2。Pythonは、簡潔な構文と強力な標準ライブラリを備えたデータサイエンスと機械学習に適しています。選択するときは、プロジェクトの要件に基づいて決定する必要があります。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHPが多くのWebサイトよりも優先テクノロジースタックである理由には、その使いやすさ、強力なコミュニティサポート、広範な使用が含まれます。 1)初心者に適した学習と使用が簡単です。 2)巨大な開発者コミュニティと豊富なリソースを持っています。 3)WordPress、Drupal、その他のプラットフォームで広く使用されています。 4)Webサーバーとしっかりと統合して、開発の展開を簡素化します。

PHPは、特にWeb開発の分野で、最新のプログラミングで強力で広く使用されているツールのままです。 1)PHPは使いやすく、データベースとシームレスに統合されており、多くの開発者にとって最初の選択肢です。 2)動的コンテンツ生成とオブジェクト指向プログラミングをサポートし、Webサイトを迅速に作成および保守するのに適しています。 3)PHPのパフォーマンスは、データベースクエリをキャッシュおよび最適化することで改善でき、その広範なコミュニティと豊富なエコシステムにより、今日のテクノロジースタックでは依然として重要になります。

PHPでは、弱い参照クラスを通じて弱い参照が実装され、ガベージコレクターがオブジェクトの回収を妨げません。弱い参照は、キャッシュシステムやイベントリスナーなどのシナリオに適しています。オブジェクトの生存を保証することはできず、ごみ収集が遅れる可能性があることに注意する必要があります。

\ _ \ _ Invokeメソッドを使用すると、オブジェクトを関数のように呼び出すことができます。 1。オブジェクトを呼び出すことができるように\ _ \ _呼び出しメソッドを定義します。 2。$ obj(...)構文を使用すると、PHPは\ _ \ _ Invokeメソッドを実行します。 3。ロギングや計算機、コードの柔軟性の向上、読みやすさなどのシナリオに適しています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

WebStorm Mac版
便利なJavaScript開発ツール

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

Dreamweaver Mac版
ビジュアル Web 開発ツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。
