MySQL数据库多表查询的方法

发布时间:2020-08-05 17:18:46 作者:小新
来源:亿速云 阅读:297

MySQL数据库多表查询的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!

MySQL多表查询

添加练习表

-- 用户表(user)
CREATE TABLE `user`(
	`id` INT AUTO_INCREMENT PRIMARY KEY COMMENT '用户id(主键)',
	`username` VARCHAR(50) COMMENT '用户姓名', 
	`age` CHAR(3) COMMENT '用户年龄'
);

-- 订单表(orders)
CREATE TABLE `orders`(
	`id` INT AUTO_INCREMENT PRIMARY KEY COMMENT '订单id(主键)',
	`price` DOUBLE COMMENT '订单价格',
	`user_id` INT COMMENT '用户id(外键)'
);

-- 给已经存在的表添加外键,语法如下
-- alter table 表名 add constraint [外键名字] foreign key (外键字段) references 父表(主键字段);
ALTER TABLE orders ADD CONSTRAINT user_fk FOREIGN KEY (user_id) REFERENCES `user` (id);

-- 向user表中添加数据
INSERT INTO USER VALUES(1,'第一',11);
INSERT INTO USER VALUES(2,'小二',12);
INSERT INTO USER VALUES(3,'张三',33);
INSERT INTO USER VALUES(4,'李四',24);
INSERT INTO USER VALUES(5,'王五',17);
INSERT INTO USER VALUES(6,'赵六',36);
INSERT INTO USER VALUES(7,'七七',18);
INSERT INTO USER VALUES(8,'粑粑',NULL);

-- 向orders 表中插入数据
INSERT INTO orders VALUES(111,1314,3);
INSERT INTO orders VALUES(112,122,3);
INSERT INTO orders VALUES(113,15,4);
INSERT INTO orders VALUES(114,315,5);
INSERT INTO orders VALUES(115,1014,NULL);
INSERT INTO orders VALUES(116,666,6);
INSERT INTO orders VALUES(117,1111,1);
INSERT INTO orders VALUES(118,8888,NULL);

MySQL数据库多表查询的方法

MySQL数据库多表查询的方法

笛卡尔积

SELECT * FROM `user`,`orders`;

MySQL数据库多表查询的方法

SELECT * FROM `user` AS u,`orders` AS o WHERE u.`id`=o.`user_id`;

MySQL数据库多表查询的方法

1.内连接

1.1隐式内连接

SELECT * FROM `user` AS u,`orders` AS o WHERE u.`id`=o.`user_id`;

MySQL数据库多表查询的方法

1.2显示内连接(推荐使用)

SELECT * FROM `user` u JOIN `orders` o ON u.`id`=o.`user_id` WHERE age >= 18;

MySQL数据库多表查询的方法

2.外连接

2.1右外链接

SELECT * FROM `user` u RIGHT JOIN `orders` o ON u.`id`=o.`user_id`;

MySQL数据库多表查询的方法

左边表数据(user)

MySQL数据库多表查询的方法

右边表数据(orders)

MySQL数据库多表查询的方法

2.2左外链接(推荐使用)

SELECT * FROM `user` u LEFT JOIN `orders` o ON u.`id`=o.`user_id`;

MySQL数据库多表查询的方法

左边表数据(user)

MySQL数据库多表查询的方法

右边表数据(orders)

MySQL数据库多表查询的方法

3.子查询

SELECT * FROM orders o WHERE o.`user_id` IN (
	SELECT u.`id` FROM `user` u WHERE u.`age` IN(
		SELECT MAX(u.`age`) FROM `user` u
	)
);

MySQL数据库多表查询的方法

4.全连接(MySQL不支持)

MySQL其它文章,请看下面链接

MySQL DDL 语句

MySQL CRUD 语句

MySQL 聚合函数

MySQL 多表查询

END…

感谢各位的阅读!看完上述内容,你们对MySQL数据库多表查询的方法大概了解了吗?希望文章内容对大家有所帮助。如果想了解更多相关文章内容,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. MYSQL的多表查询
  2. ThinkPHP多表查询

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql 多表查询

上一篇:WordPress REST API有哪些基本使用

下一篇:python flask 消息闪现

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》