Maison > programmation quotidienne > connaissance de MySQL > Résoudre le problème de requête N+1 de la base de données

Résoudre le problème de requête N+1 de la base de données

步履不停
Libérer: 2019-06-19 09:41:50
original
9888 Les gens l'ont consulté

Résoudre le problème de requête N+1 de la base de données

Exigences

Le tableau de données est le suivant :

Tableau des départements

|id|nom|

table utilisateur

|id|name|department_id|

L'exigence est d'obtenir des données avec la structure suivante :

[
    {        "id":1,        "name":"test",        "department_id":1,        "department":{            "id":1,            "name":"测试部门"
        }
    }
]
Copier après la connexion

Méthode 1 : requête en boucle

  1. Interroger la liste des utilisateurs

  2. Bouclez la liste des utilisateurs pour interroger les informations du service correspondant

$users = $db->query('SELECT * FROM `user`');foreach($users as &$user) {
    $users['department'] = $db->query('SELECT * FROM `department` WHERE `id` = '.$user['department_id']);
}
Copier après la connexion

Le nombre de requêtes car cette méthode est : 1+N (1 liste de requêtes, département de requêtes N fois), a les performances les plus faibles et n’est pas recommandée.

方法二:连表

  1. 通过连表查询用户和部门数据

  2. 处理返回数据

$users = $db->query('SELECT * FROM `user` INNER JOIN `department` ON `department`.`id` = `user`.`department_id`');// 手动处理返回结果为需求结构
Copier après la connexion

该方法其实也有局限性,如果 userdepartment 不在同一个服务器是不可以连表的。

方法三:1+1查询

  1. 该方法先查询1次用户列表

  2. 取出列表中的部门ID组成数组

  3. 查询步骤2中的部门

  4. 合并最终数据

代码大致如下:

$users = $db->query('SELECT * FROM `user`');
$departmentIds =[ ];foreach($users as $user) {    if(!in_array($user['department_id'], $departmentIds)) {
        $departmentIds[] = $user['department_id'];
    }
}
$departments = $db->query('SELECT * FROM `department` WHERE id in ('.join(',',$department_id).')');
$map = []; // [部门ID => 部门item]foreach($departments as $department) {
    $map[$department['id']] = $department;
}foreach($users as $user) {
    $user['department'] = $map[$user['department_id']] ?? null;
 }
Copier après la connexion

该方法对两个表没有限制,在目前微服务盛行的情况下是比较好的一种做法。

更多MySQL相关技术文章,请访问MySQL教程栏目进行学习!

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal