Le framework Yii est un framework d'application Web PHP open source qui fournit de nombreux outils et composants pour simplifier le processus de développement d'applications Web, dont la requête de données est l'un des composants importants. Dans le framework Yii, nous pouvons utiliser une syntaxe de type SQL pour accéder à la base de données afin d'interroger et de manipuler les données efficacement.
Le générateur de requêtes du framework Yii comprend principalement les types suivants : requête Active Record, requête Query Builder, requête de commande et requête SQL originale. Cet article présentera ces générateurs de requêtes et comment les utiliser un par un pour aider les débutants à mieux maîtriser l'utilisation des requêtes de données dans le framework Yii.
Le mode Active Record est l'un des modes d'accès aux données les plus couramment utilisés dans le framework Yii. Il fournit une interface orientée objet qui nous permet d'exploiter les données dans la base de données tout comme les instances orientées objet. . Dans le framework Yii, chaque classe Active Record correspond à une table de base de données, et on peut accéder aux données de la table en appelant la méthode statique de la classe.
Ce qui suit est un exemple de requête Active Record :
//创建一个Active Record对象 $post = Post::findOne(1); //输出该对象的属性 echo $post->title;
Dans cet exemple, nous utilisons d'abord la méthode findOne()
pour créer une instance de la classe Post
. Cette méthode interrogera l'enregistrement avec la clé primaire 1 dans la table Post
de la base de données et renverra un objet Active Record ; nous utiliserons ensuite l'attribut title
de l'objet pour. accéder à l'attribut titre de l'enregistrement. findOne()
方法创建了一个Post
类的实例,这个方法会查询数据库中Post
表中主键为1的记录并返回一个Active Record对象;然后我们使用该对象的title
属性来访问该记录的标题属性。
在实际开发中,我们通常需要对数据进行过滤、排序、分页等操作。Yii框架提供了丰富的方法来实现这些功能。例如,我们可以使用where()
方法来添加过滤条件,使用orderBy()
方法来指定排序方式,使用limit()
方法来限制返回的记录数,使用offset()
方法来指定返回记录的起始位置。以下是一个例子:
//查询标题包含“Yii”并且作者为“admin”的文章,并按照发布时间倒序排序,返回前10条记录 $posts = Post::find()->where(['like', 'title', 'Yii']) ->andWhere(['author' => 'admin']) ->orderBy(['created_at' => SORT_DESC]) ->limit(10) ->offset(0) ->all();
这个例子中,我们使用了find()
方法创建了一个Active Record查询对象,然后使用where()
和andWhere()
方法添加了两个过滤条件,分别是标题包含“Yii”和作者为“admin”;使用orderBy()
方法指定了按照发布时间倒序排序;使用limit()
方法限制了返回的记录数为10条;使用offset()
方法指定返回记录的起始位置为0条记录。最后,我们使用all()
方法执行查询,并返回所有符合要求的记录。
Query Builder是Yii框架中另一个常用的数据访问方式,它提供了一种链式调用的方式来构建SQL查询语句,比较适合于复杂的查询需求。在Yii框架中,我们可以使用Yii::$app->db->createCommand()
方法创建一个Query Builder对象,然后使用该对象的一系列方法来构建查询语句。
以下是一个Query Builder查询的例子:
//创建一个查询构建器对象,并构建查询语句 $query = Yii::$app->db->createCommand() ->select('id, title, content') ->from('post') ->where(['like', 'title', 'Yii']) ->andWhere(['author' => 'admin']) ->orderBy(['created_at' => SORT_DESC]) ->limit(10) ->offset(0); //执行查询,并返回结果集 $posts = $query->queryAll();
这个例子中,我们首先使用Yii::$app->db->createCommand()
方法创建了一个Query Builder对象,然后使用该对象的select()
、from()
、where()
、andWhere()
、orderBy()
、limit()
和offset()
等方法来构建查询语句。最后,我们使用queryAll()
方法执行查询,并返回所有符合要求的记录。
Query Builder与Active Record最大的区别在于,Query Builder不需要定义模型类,因此适用于一些简单的查询场景,如统计类查询。
命令查询是Yii框架中最原始的数据访问方式,我们可以使用该方式来执行一些不需要返回结果集的数据库操作,如更新、删除、插入等。在Yii框架中,我们可以使用Yii::$app->db->createCommand()
方法创建一个Command对象,然后使用该对象的execute()
方法来执行SQL语句。
以下是一个命令查询的例子:
//创建一个命令对象,并执行SQL语句 Yii::$app->db->createCommand() ->update('post', ['status' => 1], 'author = "admin"') ->execute();
这个例子中,我们首先使用Yii::$app->db->createCommand()
方法创建了一个Command对象,然后使用该对象的update()
方法构建了一条更新语句,该语句将post
表中所有author
为“admin”的记录的状态属性更新为1;最后,我们使用execute()
方法执行该更新语句。
在一些特殊情况下,我们可能需要执行一些复杂的查询语句,无法通过Active Record、Query Builder或命令查询来处理,这时可以使用原始SQL查询。在Yii框架中,我们可以使用Yii::$app->db->createCommand()
方法创建一个Command对象,然后使用该对象的setSql()
方法来指定原始的SQL语句,并使用queryAll()
where()
pour ajouter des conditions de filtre, la méthode orderBy()
pour spécifier la méthode de tri et la méthode limit()< Méthode /code> Pour limiter le nombre d'enregistrements renvoyés, utilisez la méthode <code>offset()
pour spécifier la position de départ des enregistrements renvoyés. Voici un exemple : //创建一个命令对象,并执行原始SQL查询 $connection = Yii::$app->db; $command = $connection->createCommand(" SELECT p.id, p.title, u.username FROM post p LEFT JOIN user u ON p.author_id = u.id WHERE p.status = 1 AND u.role = 'admin' ORDER BY p.created_at DESC LIMIT 10 OFFSET 0 "); $posts = $command->queryAll();
find()
pour créer un objet de requête Active Record, puis utilisons where()
et < code> La méthode andWhere() ajoute deux conditions de filtre, à savoir que le titre contient "Yii" et que l'auteur est "admin" ; la méthode orderBy()
est utilisée pour spécifier le tri dans ordre inverse du temps de publication ; utilisez la méthode limit()
limite le nombre d'enregistrements renvoyés à 10 ; utilisez la méthode offset()
pour spécifier la position de départ de l'enregistrement renvoyé ; enregistrements est 0 enregistrement. Enfin, nous utilisons la méthode all()
pour exécuter la requête et renvoyer tous les enregistrements qui répondent aux exigences. 🎜Yii::$app->db->createCommand()
pour créer un objet Query Builder, puis utiliser une série de méthodes de l'objet pour construire des instructions de requête. 🎜🎜Ce qui suit est un exemple de requête Query Builder : 🎜rrreee🎜Dans cet exemple, nous créons d'abord un objet Query Builder à l'aide de Yii::$app->db->createCommand()
méthode , puis utilisez les select()
, from()
, where()
, andWhere()</code de l'objet >, des méthodes telles que <code>orderBy()
, limit()
et offset()
sont utilisées pour construire des instructions de requête. Enfin, nous utilisons la méthode queryAll()
pour exécuter la requête et renvoyer tous les enregistrements qui répondent aux exigences. 🎜🎜La plus grande différence entre Query Builder et Active Record est que Query Builder n'a pas besoin de définir des classes de modèle, il convient donc à certains scénarios de requêtes simples, tels que les requêtes statistiques. 🎜Yii::$app->db->createCommand()
pour créer un objet Command, puis utiliser le execute()< de l'objet. /code >Méthode pour exécuter des instructions SQL. 🎜🎜Ce qui suit est un exemple de requête de commande : 🎜rrreee🎜Dans cet exemple, nous créons d'abord un objet Command en utilisant la méthode Yii::$app->db->createCommand()
, puis Une instruction update est construite à l'aide de la méthode update()
de l'objet, qui met à jour tous les enregistrements de la table post
dont author
est "admin " L'attribut status est mis à jour à 1 ; enfin, nous utilisons la méthode execute()
pour exécuter l'instruction update. 🎜🎜Requête SQL originale🎜🎜🎜Dans certains cas particuliers, nous pouvons avoir besoin d'exécuter des instructions de requête complexes qui ne peuvent pas être traitées via Active Record, Query Builder ou une requête de commande. Dans ce cas, vous pouvez. utilisez la requête SQL originale. Dans le framework Yii, nous pouvons utiliser la méthode Yii::$app->db->createCommand()
pour créer un objet Command, puis utiliser le setSql()< de l'objet. /code > pour spécifier l'instruction SQL d'origine et exécuter la requête à l'aide de la méthode <code>queryAll()
. 🎜🎜Ce qui suit est un exemple de requête SQL brute : 🎜//创建一个命令对象,并执行原始SQL查询
$connection = Yii::$app->db;
$command = $connection->createCommand("
SELECT p.id, p.title, u.username
FROM post p LEFT JOIN user u ON p.author_id = u.id
WHERE p.status = 1 AND u.role = 'admin'
ORDER BY p.created_at DESC
LIMIT 10 OFFSET 0
");
$posts = $command->queryAll();
Copier après la connexionCopier après la connexion这个例子中,我们首先创建了一个Command对象,并使用setSql()
方法指定一条原始的SQL查询语句。该语句将post
表和user
表进行左连接,查询出所有状态为1且用户角色为“admin”的文章,并按照发布时间倒序排序,返回前10条记录。最后,我们使用queryAll()
方法执行该查询,并返回所有符合要求的记录。
总结:
在Yii框架中,我们可以使用多种方式来访问数据库中的数据,包括Active Record查询、Query Builder查询、命令查询和原始SQL查询。不同的查询构建器适用于不同的查询场景,我们需要根据实际需求来选择最合适的查询方式。通过本文的介绍,相信读者已经对Yii框架中的数据查询有了更深入的了解,希望对大家在实际开发中使用Yii框架有所帮助。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!