【一】.介绍
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
【四】.注意交叉连接的表数据不得为空
假如交叉连接的某个表没有数据,整体返回结果集是空的
1.定长和变长的分离 如int,char,time所占字节是固定的字段放在一张表 如varchar,text所占字节不确定的字段放在一张表中2.常用字段和不常用字段进行分离,根据查询频率来设计3.一对多的关联表可以添加冗余字段,如商品分类表 和商品表 ,在首页中需要显示每个分类商...
where与having非常类似.都能筛选数据.表达式完全一致. 但是职责的确不同.where负责对表中的字段进行筛选,having负责对where筛选后的结果集再次筛选。这也就是where不能使用别名字段来筛选的原因,因为数据中没有这个字段。&n...
例如我们需要查询商品表中每个分类中商品id最大的记录,并且显示商品价格以下是表结构:id catename title &nb...
Left join:即左连接,是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。Right join:即右连接,是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表...
一般情况下,绝大部分,我们的主键是数字,1 2 3 4...所以我们才让它递增.这并不意味着,他们两个必须要绑定在一起使用.例如我还想将用户表的email字段设置为主键,但是并没有必要为其设置自增。 因此可...
我们从一个结果集中查询信息一般都是select * from (select...),每次都要编写from (select...)非常麻烦,于是我们将结果集保存起来,这就是视图的便利。创建视图的命令为:create view &nb...