Requête de connexion
Lors de l'exécution d'une requête de connexion multi-tables, vous devez spécifier la table à laquelle appartient le champ, ce qui peut améliorer l'efficacité de la requête si vous ne spécifiez pas la table à laquelle appartient le champ, la base de données. recherchera le champ de chaque table
e . Nom du champ : Représente la prise d'un certain champ de la table emp
emp comme e : Le mécanisme d'alias de la table, vous pouvez omettre as et l'écrire directement comme. emp e
Requête de connexion : elle peut également être appelée requête croisée, ce qui est nécessaire. Associez plusieurs tables pour interroger les données ensemble
Rejoignez la table emp et la table dept pour interroger les données, prenez le nom de l'employé de la table emp et prenez le nom du département de la table dept
Remarque : assurez-vous de faire la requête de connexion lorsque vous faites Il est nécessaire d'écrire les conditions associées pour éviter le phénomène de produit cartésien
Classification de requêtes de jointure
Classification basée sur l'âge de la grammaire
SQL92 :La grammaire apparue en 1992
Inconvénients de sql92 : La structure n'est pas claire, les conditions de connexion de la table, et les conditions pour un filtrage ultérieur dans une étape ultérieure, tous sont placés après où
SQL99 : La syntaxe apparue en 1999 (apprentissage des clés)
sql99 avantages : conditions de connexion aux tables et requêtes Séparation conditionnelle, si un filtrage supplémentaire est nécessaire après la connexion, continuez à ajouter où plus tard, ce sera plus clair lors de la connexion de plusieurs tables
Classification selon le mode de connexion de la table
Jointure interne : jointure égale, jointure non égale Jointure de valeur, auto-jointure , l'intérieur peut être omis et généralement non ajouté
Table A jointure interne Tableau B sur les conditions d'association
Jointure externe : jointure externe gauche (jointure gauche), jointure externe droite (jointure droite), boîte externe Généralement pas ajoutez
table A jointure externe gauche table B sur condition d'association
table B jointure externe droite table A sur condition d'association
La jointure gauche doit être basée sur la table de gauche et comparée à la table à droite. Toutes les inégalités égales au tableau de gauche seront affichées, tandis que celles du tableau de droite qui remplissent les conditions seront affichées, et celles qui ne remplissent pas les conditions ne seront pas affichées (la jointure de droite est juste le contraire). )
La fonction que la jointure gauche peut remplir peut certainement être complétée par la jointure droite
Jointure complète, les deux tables connectées sont toutes deux des tables principales et peuvent être interrogées
Phénomène de produit cartésien
Quand deux les tables sont connectées pour la requête et aucune condition de connexion n'est spécifiée, le nombre final de résultats de requête est de deux entrées de table Le produit des nombres, ce phénomène est appelé : Phénomène de produit cartésien (découvert par Descartes, c'est un phénomène mathématique)
Évitez le Phénomène de produit cartésien : ajoutez des conditions de connexion lors de la connexion de plusieurs tables, et les enregistrements qui remplissent cette condition ont été filtrés
Le nombre de correspondances n'a pas diminué pendant le processus de correspondance, mais le nombre de résultats finaux de la requête est devenu inférieur car il était filtré en fonction des conditions de connexion
On peut conclure grâce au phénomène de produit cartésien que la table Plus le nombre de connexions est élevé, plus l'efficacité est faible. Essayez d'éviter le nombre de connexions de table
Equi-jointures de. jointures internes
Parce que les conditions sont égales, elles sont appelées équi-jointures (données qui joignent des conditions égales)
Recherchez le nom du service où se trouve chaque employé, affichez le nom de l'employé et le service
emp e et Les tables du département d sont connectées, la condition de connexion est : e.deptno = d.deptno
--sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面 select e.ename,d.dname from emp e, dept d where e.deptno = d.deptno; --sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加where select e.ename,d.dname from emp e --inner可以省略(带着inner可读性更好) (inner) join dept d on e.deptno = d.deptno;
Inner join self-join
Parce qu'il n'y a qu'une seule table de connexion, la méthode de requête spécifique consiste à traiter une table comme deux tables et à se connecter eux-mêmes, cela devient donc une auto-adhésion
Pour interroger le leader supérieur de l'employé, il est nécessaire d'afficher le nom de l'employé et le nom du leader correspondant
Une table est traitée comme deux tables Zhang, emp e représente la table des employés , et emp m représente également la table des leaders
Conditions de connexion : e.mgr = m.empno numéro d'employé du leader = numéro d'employé du leader
--SQL92 select e.ename, m.ename from emp e, emp m where e.mgr=m.empno; --SQL99 select a.ename as '员工名', b.ename as '领导名' from emp e join emp m on e.mgr = m.empno;
Jointure non équivalente de la jointure interne
Parce que la condition de connexion n'est pas une relation d'équivalence, cela s'appelle une connexion non équivalente
Afficher les informations sur les employés dont le salaire est supérieur à 2000, et afficher le nom du service auquel il appartient
--采用 SQL92 语法 select e.ename, e.sal, d.dname from emp e, dept d where e.deptno=d.deptno and e.sal > 2000; --采用 SQL99 语法 select e.ename, e.sal, d.dname from emp e (inner) join dept d on e.deptno=d.deptno where e.sal>2000;
Connaître l'échelon salarial de chaque employé et exiger l'affichage de employés Nom, salaire, grade de salaire
select e.ename, e.sal, s.grade from emp e (inner) join salgrade s on e.sal between s.losal and s.hisal;
Jointure externe
Jointure externe : dans la jointure externe, la connexion de deux tables crée une relation primaire et secondaire. La requête principale concerne les données de la table principale et de la table secondaire. est interrogé avec l'association, c'est-à-dire si l'autre partie S'il n'y a aucun enregistrement correspondant à ma table principale, alors la contrepartie par défaut est nulle et le mot-clé externe peut être omis
Jointure externe droite : celle avec le droit est une jointure externe droite, ce qui signifie que la table à droite du mot clé join est considérée comme la table principale, principalement pour interroger toutes les données de cette table, et interroger la table de gauche avec l'association
Left external join : avec left t est une jointure externe gauche, ce qui signifie regarder la table à gauche du mot-clé join. La table principale consiste à interroger toutes les données de cette table et à interroger la table de droite avec l'association
**Remarque : toute jointure à droite a une jointure à gauche, et toute jointure à gauche a une droite. Comment écrire une connexion**
查询每个员工的上级领导,要求显示所有员工的名字和领导名 , 如果某个员工没有领导 , 那么该员工也必须显示出来
--左连接 select a.ename as '员工名', b.ename as '领导名' from emp a left (outer) join emp b on a.mgr = b.empno; --右连接 select a.ename as '员工名', b.ename as '领导名' from emp b right (outer) join emp a on a.mgr = b.empno;
内连接和外连接的特点
内连接:A表和B表连接,A和B两张表没有主次关系是平等的 , 查询时只是将能够匹配上连接条件的数据查询出来 , 即如果没有匹配的就查询不出来 , inner关键字可以省略
外连接: 在外连接当中,两张表连接产生了主次关系 , 主要查询的是主表的数据 , 捎带着关联查询次表 , 即如果对方没有记录和我主表匹配 , 那么默认对方是null , outer关键字可以省略
注意: 区分内外连接的办法是通过 right 和 left 关键字 , 不是通过 inner 和 outer 因为它们都可以省略 , 并且外连接的查询结果条数一定是大于等于内连接的查询结果条数
显示员工信息,并显示所属的部门名称
select e.ename,d.dname from emp e join dept d on e.deptno = d.deptno;
显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来
--外连接(右外连接) select e.ename,d.dname from emp e --outer是可以省略的,带着可读性强 --right代表什么:表示将join关键字右边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询左边的表 right (outer) join dept d on e.deptno = d.deptno; --外连接(左外连接) select e.ename,d.dname from dept d --outer是可以省略的,带着可读性强 left (outer) join emp e on e.deptno = d.deptno;
多表连接
一条SQL中内连接和外连接可以混合 , 都可以出现
--表示一: a 和 b 进行内连接 , a 和 c 进行内连接 , a 和 d 进行右外连接(推荐) --表示二: a 和 b 的内连接结果去内连接 c 的结果再去右外连接 d select ... from a join b on a和b的连接条件 join c on a和c的连接条件 right join d on a和d的连接条件
找出每个员工的部门名称以及工资等级,要求显示员工名、部门名、薪资、薪资等级
select e.ename,e.sal,d.dname,s.grade from emp e join dept d on e.deptno = d.deptno join salgrade s on e.sal between s.losal and s.hisal;
查询结果
+--------+---------+------------+-------+ | ename | sal | dname | grade | +--------+---------+------------+-------+ | SMITH | 800.00 | RESEARCH | 1 | | ALLEN | 1600.00 | SALES | 3 | | WARD | 1250.00 | SALES | 2 | | JONES | 2975.00 | RESEARCH | 4 | | MARTIN | 1250.00 | SALES | 2 | | BLAKE | 2850.00 | SALES | 4 | | CLARK | 2450.00 | ACCOUNTING | 4 | | SCOTT | 3000.00 | RESEARCH | 4 | | KING | 5000.00 | ACCOUNTING | 5 | | TURNER | 1500.00 | SALES | 3 | | ADAMS | 1100.00 | RESEARCH | 1 | | JAMES | 950.00 | SALES | 1 | | FORD | 3000.00 | RESEARCH | 4 | | MILLER | 1300.00 | ACCOUNTING | 2 | +--------+---------+------------+-------+
找出每个员工的部门名称以及工资等级,还有上级领导,要求显示员工名、领导名、部门名、薪资、薪资等级
select e.ename,e.sal,d.dname,s.grade,l.ename from emp e join dept d on e.deptno = d.deptno join salgrade s on e.sal between s.losal and s.hisal left join emp l on e.mgr = l.empno;
查询结果
+--------+---------+------------+-------+-------+ | ename | sal | dname | grade | ename | +--------+---------+------------+-------+-------+ | SMITH | 800.00 | RESEARCH | 1 | FORD | | ALLEN | 1600.00 | SALES | 3 | BLAKE | | WARD | 1250.00 | SALES | 2 | BLAKE | | JONES | 2975.00 | RESEARCH | 4 | KING | | MARTIN | 1250.00 | SALES | 2 | BLAKE | | BLAKE | 2850.00 | SALES | 4 | KING | | CLARK | 2450.00 | ACCOUNTING | 4 | KING | | SCOTT | 3000.00 | RESEARCH | 4 | JONES | | KING | 5000.00 | ACCOUNTING | 5 | NULL | | TURNER | 1500.00 | SALES | 3 | BLAKE | | ADAMS | 1100.00 | RESEARCH | 1 | SCOTT | | JAMES | 950.00 | SALES | 1 | BLAKE | | FORD | 3000.00 | RESEARCH | 4 | JONES | | MILLER | 1300.00 | ACCOUNTING | 2 | CLARK | +--------+---------+------------+-------+-------+
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!

InnodBBufferPool réduit les E / S de disque en mettant en cache des données et des pages d'indexation, améliorant les performances de la base de données. Son principe de travail comprend: 1. La lecture des données: lire les données de BufferPool; 2. Écriture de données: Après avoir modifié les données, écrivez dans BufferPool et actualisez-les régulièrement sur le disque; 3. Gestion du cache: utilisez l'algorithme LRU pour gérer les pages de cache; 4. Mécanisme de lecture: Chargez à l'avance des pages de données adjacentes. En dimensionner le tampon et en utilisant plusieurs instances, les performances de la base de données peuvent être optimisées.

Par rapport à d'autres langages de programmation, MySQL est principalement utilisé pour stocker et gérer les données, tandis que d'autres langages tels que Python, Java et C sont utilisés pour le traitement logique et le développement d'applications. MySQL est connu pour ses performances élevées, son évolutivité et son support multiplateforme, adapté aux besoins de gestion des données, tandis que d'autres langues présentent des avantages dans leurs domaines respectifs tels que l'analyse des données, les applications d'entreprise et la programmation système.

MySQL vaut la peine d'être appris car il s'agit d'un puissant système de gestion de la base de données open source adapté au stockage, à la gestion et à l'analyse des données. 1) MySQL est une base de données relationnelle qui utilise SQL pour faire fonctionner les données et convient à la gestion structurée des données. 2) Le langage SQL est la clé pour interagir avec MySQL et prend en charge les opérations CRUD. 3) Le principe de travail de MySQL inclut l'architecture client / serveur, le moteur de stockage et l'optimiseur de requête. 4) L'utilisation de base comprend la création de bases de données et de tables, et l'utilisation avancée implique de rejoindre des tables à l'aide de la jointure. 5) Les erreurs courantes incluent les erreurs de syntaxe et les problèmes d'autorisation, et les compétences de débogage incluent la vérification de la syntaxe et l'utilisation des commandes Explication. 6) L'optimisation des performances implique l'utilisation d'index, l'optimisation des instructions SQL et la maintenance régulière des bases de données.

MySQL convient aux débutants pour acquérir des compétences de base de données. 1. Installez les outils MySQL Server et Client. 2. Comprendre les requêtes SQL de base, telles que SELECT. 3. 掌握数据操作: : 创建表、插入、更新、删除数据。 4. 学习高级技巧: : 子查询和窗口函数。 5. 调试和优化: : 检查语法、使用索引、避免 Sélectionner * , 并使用 Limite。

MySQL gère efficacement les données structurées par la structure de la table et la requête SQL, et met en œuvre des relations inter-tableaux à travers des clés étrangères. 1. Définissez le format de données et tapez lors de la création d'une table. 2. Utilisez des clés étrangères pour établir des relations entre les tables. 3. Améliorer les performances par l'indexation et l'optimisation des requêtes. 4. Bases de données régulièrement sauvegarde et surveillent régulièrement la sécurité des données et l'optimisation des performances.

MySQL est un système de gestion de base de données relationnel open source qui est largement utilisé dans le développement Web. Ses caractéristiques clés incluent: 1. Prend en charge plusieurs moteurs de stockage, tels que InNODB et Myisam, adaptés à différents scénarios; 2. Fournit des fonctions de réplication à esclave maître pour faciliter l'équilibrage de la charge et la sauvegarde des données; 3. Améliorez l'efficacité de la requête grâce à l'optimisation des requêtes et à l'utilisation d'index.

SQL est utilisé pour interagir avec la base de données MySQL pour réaliser l'ajout de données, la suppression, la modification, l'inspection et la conception de la base de données. 1) SQL effectue des opérations de données via des instructions SELECT, INSERT, UPDATE, DELETE; 2) Utiliser des instructions Create, Alter, Drop pour la conception et la gestion de la base de données; 3) Les requêtes complexes et l'analyse des données sont mises en œuvre via SQL pour améliorer l'efficacité de la prise de décision commerciale.

Les opérations de base de MySQL incluent la création de bases de données, les tables et l'utilisation de SQL pour effectuer des opérations CRUD sur les données. 1. Créez une base de données: CreatedAtAbaseMy_First_DB; 2. Créez un tableau: CreateTableBooks (idIntauto_inCmentPrimaryKey, TitleVarchar (100) notnull, AuthorVarchar (100) notnull, publied_yearint); 3. Données d'insertion: INSERTINTOBOOKS (titre, auteur, publié_year) VA


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Télécharger la version Mac de l'éditeur Atom
L'éditeur open source le plus populaire

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.