前言

Mysql基础篇相关的内容是看了康师傅的视频做的笔记吧

数据库相关概念

  • DB: 数据库(Database)

存储数据的仓库,本质是一个文件系统。它保存了一系列有组织的数据。

  • DBMS:数据库管理系统(Database Management System)
    操作和管理数据库的大型软件。(平常我们说的mysql、oracle等其实是DBMS)
  • SQL: 结构化查询语言(Structured Query Language)
    与数据库通信的语言。
  • RDBMS:关系型数据库管理系统
    是最古老的数据库类型,把复杂的数据结构归结为简单的二元关系(即二维表格形式)。
  • 非RDBMS:非关系型数据库管理系统
    不是按照简单二元关系存储的数据库。有键值型数据库【redis】、文档型数据库【MongoDB、CouchDB】、搜索引擎数据库【elasticsearch、Solr、Splunk】、列式数据库【HBase】、图形数据库【Neo4j、InfoGrid】
  • DDL:数据库定义语言(Data Definition Language)
    数据库对象(数据库、表、触发器、视图等)的增删改查。
  • DML:数据库操作语言(Data Manipulation Language)
    表数据的增删改查。
  • DCL:数据库控制语言(Data Control Language)
    常见于数据库的安全管理,如Grant、Rollback等。

DML基本语法

INSERT INTO t1[(fields ...)] values(fields values);
INSERT INTO t1[(fields ...)] select */fields.. from t2;
DELETE FROM t1 [WHERE];
UPDATE t1 SET ...;
SELECT * FROM t1;

多表连接

内连接

结果是两张表的交集

示例一
select t.*, t2.*
from t1, t2
where t1.id = t2.id

示例二

select t1.*, t2.*
from t1 inner join t2
on t1.id = t2.id

外连接

左外连接

结果是两张表的交集+左表未匹配上的部分(其中t2.*的字段全部为null)。

select t1.*, t2.*
from t1 left join t2
on t1.id = t2.id
右外连接

结果是两张表的交集 + 右表未匹配上的部分(其中t1.*的字段全部为null)。

select t1.*, t2.*
from t1 right join t2
on t1.id = t2.id
满外连接

结果是两张表的交集 + 左表未匹配上的部分(其中t2.*的字段全部为null)+ 右表未匹配上的部分(其中t1.*的字段全部为null)。

UNION 使用

select * from t1
union [all] 
select * from t2
union和union all

都是取两个结果集的并集,union会去重,union all 不会去重,所以union all执行效率高于union。

自然连接(NATURAL JOIN)

SQL99语法的新特性,会帮你自动查询两张表所有相同的字段然后进行等值连接

select t1.*, t2.*
from t1 natural join t2

USING连接

同样是SQL99的新特性,指定具体的相同字段进行等值连接

select t1.*, t2.*
from t1 join t2
USING(id)

表连接的三种约束,WHERE、ON、USING

  • WHERE 适合所有关联查询
  • ON 只能和JOIN一起使用
  • USING 只能和JOIN一起使用,且两张表的制定字段名字必须相同