MySQL进阶

本文介绍了数据库中的一对一、一对多和多对多表的关系,详细讲解了内连接查询、外连接查询(左外连接、右外连接)的用法,并展示了如何进行子查询、自关联查询以及视图的创建、修改和删除。此外,还讨论了数据库的备份和恢复过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一对一表

一对多表

多对多表(借助第三张中间表,同时关联两张表)

多表查询:

  1. 内连接查询:

/*

显示内连接

标准语法:

SELECT 列名 FROM 表名1 [INNER] JOIN 表名2 ON 关联条件;

*/

-- 查询用户信息和对应的订单信息

SELECT * FROM USER INNER JOIN orderlist ON orderlist.uid = user.id;

-- 查询用户信息和对应的订单信息,起别名

SELECT * FROM USER u INNER JOIN orderlist o ON o.uid=u.id;

-- 查询用户姓名,年龄。和订单编号

SELECT

u.name,-- 用户姓名

u.age,-- 用户年龄

o.number-- 订单编号

FROM

USER u -- 用户表

INNER JOIN

orderlist o -- 订单表

ON

o.uid=u.id;

/*

隐式内连接

标准语法:

SELECT 列名 FROM 表名1,表名2 WHERE 关联条件;

*/

-- 查询用户姓名,年龄。和订单编号

SELECT

u.name,-- 用户姓名

u.age,-- 用户年龄

o.number-- 订单编号

FROM

USER u,-- 用户表

orderlist o -- 订单表

WHERE

o.uid=u.id;

  1. 外连接查询:

/*

左外连接

标准语法:

SELECT 列名 FROM 表名1 LEFT [OUTER] JOIN 表名2 ON 条件;

*/

-- 查询所有用户信息,以及用户对应的订单信息

SELECT

u.*,

o.number

FROM

USER u

LEFT OUTER JOIN

orderlist o

ON

o.uid=u.id;

/*

右外连接

标准语法:

SELECT 列名 FROM 表名1 RIGHT [OUTER] JOIN 表名2 ON 条件;

*/

-- 查询所有订单信息,以及订单所属的用户信息

SELECT

o.*,

u.name

FROM

USER u

RIGHT OUTER JOIN

orderlist o

ON

o.uid=u.id;

子查询:

自关联查询:

视图:

/*

创建视图

标准语法

CREATE VIEW 视图名称 [(列名列表)] AS 查询语句;

*/

-- 创建city_country视图,保存城市和国家的信息(使用指定列名)

CREATE VIEW city_country (city_id,city_name,country_name) AS

SELECT

c1.id,

c1.name,

c2.name

FROM

city c1,

country c2

WHERE

c1.cid=c2.id;

/*

查询视图

标准语法

SELECT * FROM 视图名称;

*/

-- 查询视图

SELECT * FROM city_country;

/*

修改视图数据

标准语法

UPDATE 视图名称 SET 列名=值 WHERE 条件;

修改视图结构

标准语法

ALTER VIEW 视图名称 (列名列表) AS 查询语句;

*/

-- 修改视图数据,将北京修改为深圳。(注意:修改视图数据后,源表中的数据也会随之修改)

SELECT * FROM city_country;

UPDATE city_country SET city_name='深圳' WHERE city_name='北京';

-- 将视图中的country_name修改为name

ALTER VIEW city_country (city_id,city_name,NAME) AS

SELECT

c1.id,

c1.name,

c2.name

FROM

city c1,

country c2

WHERE

c1.cid=c2.id;

/*

删除视图

标准语法

DROP VIEW [IF EXISTS] 视图名称;

*/

-- 删除city_country视图

DROP VIEW IF EXISTS city_country;

数据库备份和恢复:

  • 备份

登录到MySQL服务器,输入:mysqldump -u root -p 数据库名称>文件保存路径

  • 恢复

  1. 登录MySQL数据库

  1. 删除已备份数据库

  1. 重新创建名称相同的数据库

  1. 使用该数据库

  1. 导入文件执行:source本份文件全路径

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

月初,

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值