【一】.介绍
mysql交叉连接官方名是cross join。
假设t1表2条记录,t2表3条记录,交叉连接后的结果就是t1表记录乘于t2表记录(2*3=6条记录)
【二】.数据演示
先展示t1表和t2表的记录:
select * from t1
t1id t1name 1 6 2 7
select * from t2
t2id t2name 1 5 2 6 3 7
再看看交叉连接后的数据
select * from t1 cross join t2
t1id t1name t2id t2name 1 6 1 5 2 7 1 5 1 6 2 6 2 7 2 6 1 6 3 7 2 7 3 7
交叉连接后的结果集就是t1表每天记录和t2表每条记录组合形成的结果集,连接图示:

【三】.推荐的写法(等价于cross join)
SELECT * from t1,t2
【四】.注意交叉连接的表数据不得为空
假如交叉连接的某个表没有数据,整体返回结果集是空的
例如我们需要查询商品表中每个分类中商品id最大的记录,并且显示商品价格以下是表结构:id catename title &nb...
需求查询出存在商品的商品分类. 先看看分类表:id(分类的id) catename(分类名) 1 手机 2 &n...
我们从一个结果集中查询信息一般都是select * from (select...),每次都要编写from (select...)非常麻烦,于是我们将结果集保存起来,这就是视图的便利。创建视图的命令为:create view &nb...
触发器是一种特殊的事务,可以监听到Mysql的(insert/update/delete)的操作并触发相应的(insert/update/delete)操作. 触发器的创建主要有4个要素:(1).监听地点(...
由于在开发中不小心删除客户上传的商品数据,客户本身也不好说话,只好恢复数据库,记录下过程。原理是数据库开启bin-log功能,然后再通过备份的bin-log进行数据库恢复。先查找备份的数据库日志二进制文件。一般在mysql的data文件夹中,文件名大概为mysql-bin.00001,具体看文件的修...
1.很多人认为count查询非常快,但是在加上筛选条件那就是未必的了!测试:user表中4000w数据(1).SELECT count(*) from user; 用时0.00s (2).SELECT...