连接可用于查询,更新,建立事实外键(指人为建立的两张表的对应关系,相对的,FORGIEN KEY也称物理外键)

表的连接实质就是外键的逆向约束

连接条件

使用ON设定连接条件,也可以用WHERE代替.

一般情况下

  • ON:设定连接条件
  • WHERE:进行结果集记录的过滤

没有条件的JOIN内连接实质就是笛卡尔积

[INNER] JOIN 内连接

在MySQL中,JOIN, CROSS JOIN 和 INNER JOIN 是等价的。

内连接表示交集,仅显示A、B两表符合连接条件的记录。不符合连接条件的记录不显示。

SELECT goods_id,goods_name,cate_name FROM tdb_goods INNER JOIN tdb_goods_cate ON tdb_goods.cate_id = tdb_goods_cate.cate_id;
--将tdb_goods表中用中文存储的goods_cate修改为tdb_goods_cates表中对应的cate_id,以节省空间UPDATE tdb_goods INNER JOIN tdb_goods_catesON goods_cate=cate_name SET goods_cate=cate_id;--tdb_goods 想要更改的表名--tdb_goods_cates 关联的附表--goods_cate=cate_name 两个表对应列的关系--goods_cate=cate_id; 设置 值

内连接比外连接用的多一些.

若某字段只存在某一表,则另一表的里字段返回 NULL

LEFT [OUTER] JOIN 左外连接

显示左表的全部记录及右表符合连接条件的记录。

  • 如果使用LEFT JOIN,左表中存在一条记录A,在右表中没有找到相应的记录,则返回结果会出现一条只有记录A中的相应字段内容,其他字段都为NULL的记录(RIGHT JOIN类似).

RIGHT [OUTER] JOIN 右外连接

显示右表的全部记录及左表符合连接条件的记录。

多表连接

跟两张表的连接类似

如三张表的连接:

SELECT goods_id,goods_name,b.cate_name,c.brand_name,goods_priceFROM products AS a INNER JOIN products_cate AS b ON a.goods_cate = b.cate_idINNER JOIN products_brand AS c ON a.brand_name = c.brand_id;

设计无限分类数据表

在同一张表中既有父类,又有子类,本质上是一棵树:

可以通过对同一张数据表的自身连接来进行查询:

--查找显示父类id对应的名称SELECT s.type_id,s.type_name,p.type_name AS parent_nameFROM tdb_goods_types AS s LEFT JOIN tdb_goods_types AS p ON s.parent_id=p.type_id;--查找子类id对应的名称SELECT p.type_id,p.type_name,s.type_name AS child_nameFROM tdb_goods_types AS pLEFT JOIN tdb_goods_types AS sON p.type_id=s.parent_id;--查找有多少子级SELECT p.type_id,p.type_name,COUNT(s.type_name) AS child_countFROM tdb_goods_types AS pLEFT JOIN tdb_goods_types AS sON p.type_id=s.parent_id GROUP BY p.type_nameORDER BY p.type_id;

这里用自连接模拟两张表,删除该表中的重复项,保留goods_id 较小的记录.

DELETE t1 FROM tdb_goods AS t1 LEFT JOIN( --选出goods_name重复的记录 SELECT goods_id,goods_name  FROM tdb_goods  GROUP BY goods_name --MySQL 5.7.5以上版本启用了only_full_group_by SQL模式,select的列都要在group中,或者本身是聚合列(SUM,AVG,MAX,MIN)才行,这里没有启用 HAVING COUNT(goods_name)>=2) AS t2 --将t1与t2进行左连接,其实这里内连接和右连接也行ON t1.goods_name=t2.goods_name --t1和t2的连接条件WHERE t1.goods_id>t2.goods_id; --在LEFT JOIN结果集中,选出满足t1.goods_id>t2.goods_id的记录

总结

更多相关文章

  1. Android官方入门文档[1]创建一个Android项目
  2. Android(安卓)开发环境入门
  3. Android入门学习笔记之人机用户界面
  4. android的常用控件总结【安卓入门五】
  5. Android(安卓)UI学习 -网址列表
  6. android 入门demo 解析xml
  7. 在Android中扫描wifi热点演示实例教程
  8. android入门知识:android使用全局变量
  9. Android消息机制入门一

随机推荐

  1. android:broadcast_01
  2. android检查sd卡是否可写
  3. Tab游标,实现fragment滑动,,游标改变
  4. PullToRefreshLayout +RecyclerView 实现
  5. 改变ProgressBar的图片
  6. android 水平(左右)滚动 HorizontalScrollV
  7. Android百度地图知识讲解
  8. Android RadioGroup RadioButton的一个小
  9. Android页面启动 editext获取焦点 scroll
  10. android常用图片特效处理