Mysql基础篇(1)—— 基础概念、DML基本语法和表连接

前言

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一起使用,且两张表的制定字段名字必须相同
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值