Home Backend Development PHP Tutorial YII2 database query practice

YII2 database query practice

Aug 04, 2016 am 09:20 AM
mysql php yii2

This article mainly introduces relevant information on YII2 database query practice. Friends who need it can refer to

Initial exploration of the yii2 framework, simple practice of basic database operations such as addition, deletion, modification, and related query.

Database configuration.

/config/db.php Configure database

During practice, there is a test library - "test table -" two records are as follows

mysql> select * from test;
+----+---- ----+
| id | name |
+----+--------+
| 1 | zhuai |
| 2 | heng |
+----+--------+
18 rows in set (0.00 sec)

sql query method

yii2 provides the original database query method findBySql; at the same time, through placeholder This method automatically performs basic SQL injection defense. Code

// The most basic query method
$sql = "select * from test where 1";
$res = Test::findBySql($sql)->all();
var_dump(count($res )); // res->2
// findbysql prevents sql injection
$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";
// The locator will automatically prevent sql injection
$res = Test::findBySql($sql,array(":id"=>$id))->all();
var_dump(count($res)); // res->1

activeRecord query method

In addition to the original sql method, each framework will provide corresponding encapsulated query methods, and the same is true for yii2.

The basic method of creating a model

yii is as follows. The code is not described in detail below.

namespace appmodels;
use Yii;
use yiidbActiveRecord;
class Test extends ActiveRecord
{
// Optional, corresponding table: If the default class name and table name match, this function is not needed
public static function tableName ()
{
return 'test';
}
// Optional, validator: mainly used to verify each field
public function rules(){
return [
['id', 'integer'],
['name', 'string', 'length' => [0, 100]],
];
}
}

You need to introduce model when using it

use appmodelsTest;
Add operation
//add Operation
$test = new Test();
$test->name = 'test';
// Legality verification
$test->validate();
if($test->hasErrors() ){
echo "Data is illegal";
die;
}
$test->save();

Query operation

Query operation first go to the official document

activeRecord doc

where doc

Need to emphasize The thing is: Yii query provides a lot of rich libraries, such as batch query processing in the code, etc. For details, please see the documentation.

// 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 <=2
$res = Test::find()->where(['between','id',1, 2])->all();
var_dump(count($res)); //2
// name field like
$res = Test::find()->where(['like', ' name', 'cuihuan'])->all();
var_dump(count($res)); //2
// Query usage obj->array
$res = Test::find()- >where(['between','id',1,2])->asArray()->all();
var_dump($res[0]['id']); //2
// Batch query, for batch query of large memory operation
foreach (Test::find()->batch(1) as $test) {
var_dump(count($test));
}

delete operation

//delete
// Select to delete
$res = Test::find()->where(['id'=>1])->all();
$res[0]->delete() ;
// Directly delete
var_dump(Test::deleteAll('id>:id', array(':id' => 2)));

Modification operation

In addition to the code method, yii2 directly provides update operation.

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

Associated query operation

Two tables in the associated query example:

A student table (student): id, name;

A score table (score): id ,stu_id,score

// All scores of the corresponding student
$stu = Student::find()->where(['name'=>'xiaozhuai'])->one();
var_dump( $stu->id);
// Basic acquisition
$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);

Two related query methods; however, when performing related operations in the controller, the code is too confusing, so the call is encapsulated in the model

First encapsulate the relevant associated calling functions in the student model

namespace appmodels;
use Yii;
use yiidbActiveRecord;
class Student extends ActiveRecord
{
public static function tableName()
{
return 'student' ;
}
//Get score information
public function getScores()
{
$scores = $this->hasMany(Score::className(), ['stu_id' => 'id'])-> asArray()->all();
return $scores;
}
}

and then called directly, two calling methods

//Call after function encapsulation
$scores = $stu->getScores() ;
var_dump($scores);
//Use the automatic calling method of __get
$scores = $stu->scores;
var_dump($scores);

Finally

deployment and use of the above in yii2 Some basic operations such as additions, deletions, modifications, and related queries during the process.

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

Choosing Between PHP and Python: A Guide Choosing Between PHP and Python: A Guide Apr 18, 2025 am 12:24 AM

PHP is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

MySQL's Role: Databases in Web Applications MySQL's Role: Databases in Web Applications Apr 17, 2025 am 12:23 AM

The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

Laravel Introduction Example Laravel Introduction Example Apr 18, 2025 pm 12:45 PM

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

PHP and Python: A Deep Dive into Their History PHP and Python: A Deep Dive into Their History Apr 18, 2025 am 12:25 AM

PHP originated in 1994 and was developed by RasmusLerdorf. It was originally used to track website visitors and gradually evolved into a server-side scripting language and was widely used in web development. Python was developed by Guidovan Rossum in the late 1980s and was first released in 1991. It emphasizes code readability and simplicity, and is suitable for scientific computing, data analysis and other fields.

PHP: An Introduction to the Server-Side Scripting Language PHP: An Introduction to the Server-Side Scripting Language Apr 16, 2025 am 12:18 AM

PHP is a server-side scripting language used for dynamic web development and server-side applications. 1.PHP is an interpreted language that does not require compilation and is suitable for rapid development. 2. PHP code is embedded in HTML, making it easy to develop web pages. 3. PHP processes server-side logic, generates HTML output, and supports user interaction and data processing. 4. PHP can interact with the database, process form submission, and execute server-side tasks.

PHP vs. Python: Use Cases and Applications PHP vs. Python: Use Cases and Applications Apr 17, 2025 am 12:23 AM

PHP is suitable for web development and content management systems, and Python is suitable for data science, machine learning and automation scripts. 1.PHP performs well in building fast and scalable websites and applications and is commonly used in CMS such as WordPress. 2. Python has performed outstandingly in the fields of data science and machine learning, with rich libraries such as NumPy and TensorFlow.

Solve database connection problem: a practical case of using minii/db library Solve database connection problem: a practical case of using minii/db library Apr 18, 2025 am 07:09 AM

I encountered a tricky problem when developing a small application: the need to quickly integrate a lightweight database operation library. After trying multiple libraries, I found that they either have too much functionality or are not very compatible. Eventually, I found minii/db, a simplified version based on Yii2 that solved my problem perfectly.

See all articles