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éthodefindOne()
pour créer une instance de la classePost
. Cette méthode interrogera l'enregistrement avec la clé primaire 1 dans la tablePost
de la base de données et renverra un objet Active Record ; nous utiliserons ensuite l'attributtitle
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 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();
Copier après la connexion
Copier après la connexion
Dans cet exemple, nous utilisons la méthode
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.
Query Builder queryQuery Builder est une autre méthode d'accès aux données couramment utilisée dans le framework Yii. Elle fournit une méthode d'appel en chaîne pour créer des instructions de requête SQL, qui est plus adaptée aux exigences de requêtes complexes. . Dans le framework Yii, nous pouvons utiliser la méthode
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 : rrreeeDans 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()
, des méthodes telles que 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.
Requête de commandeLa requête de commande est la méthode d'accès aux données la plus originale du framework Yii. Nous pouvons utiliser cette méthode pour effectuer certaines opérations de base de données qui n'ont pas besoin de renvoyer un ensemble de résultats, telles que. mettre à jour, supprimer, insérer, etc. Dans le framework Yii, nous pouvons utiliser la méthode
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 : rrreeeDans cet exemple, nous créons d'abord un objet Command en utilisant la méthodeYii::$app->db->createCommand()
, puis Une instruction update est construite à l'aide de la méthodeupdate()
de l'objet, qui met à jour tous les enregistrements de la tablepost
dontauthor
est "admin " L'attribut status est mis à jour à 1 ; enfin, nous utilisons la méthodeexecute()
pour exécuter l'instruction update.
Requête SQL originaleDans 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 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 connexion
Copier 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!
Article précédent:Traitement d'images dans le framework Yii : manipulation d'images
Article suivant:Composants de base du framework Yii
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
-
2024-08-25 12:47:24
-
2024-08-25 12:32:32
-
2024-08-25 12:31:50
-
2024-08-25 12:17:24
-
2024-08-25 12:12:24
-
2024-08-25 12:10:24
-
2024-08-25 12:01:24
-
2024-08-25 12:00:23
-
2024-08-25 11:05:05
-
2024-08-25 11:03:05
Derniers numéros
Rubriques connexes
Plus>
- Comment utiliser Swagger
- erreur d'initialisation mom.exe
- Que sont les éditeurs de texte Java ?
- Comment configurer la passerelle par défaut
- La raison pour laquelle la fonction d'en-tête renvoie un échec 404
- Étapes pour supprimer l'un des systèmes doubles
- Comment basculer entre les systèmes doubles Huawei
- Que signifie la passerelle Edge Computing ?
-
À propos de nous
Clause de non-responsabilité
Sitemap
-
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!