MySQL中多表连接的示例分析
发表于:2024-11-11 作者:千家信息网编辑
千家信息网最后更新 2024年11月11日,这篇文章主要介绍MySQL中多表连接的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!连接可用于查询,更新,建立事实外键(指人为建立的两张表的对应关系,相对的,FORGI
千家信息网最后更新 2024年11月11日MySQL中多表连接的示例分析
这篇文章主要介绍MySQL中多表连接的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
连接可用于查询,更新,建立事实外键(指人为建立的两张表的对应关系,相对的,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的记录
以上是"MySQL中多表连接的示例分析"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!
条件
字段
内容
结果
查询
示例
分析
名称
子类
实质
就是
数据
数据表
篇文章
选出
更新
两个
中用
事实
交集
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
航旅纵横软件开发岗位待遇
服务器和主机一起用
高科技软件开发代理品牌
ts怎么设置服务器组
为什么我的商店连接不到服务器
四级数据库原理考什么
嵌入式软件开发需要的技能
甲骨文免费服务器有人注册成功吗
配体数据库
软件开发项目规模划分
杭州极七网络技术有限公司
服务器rfid管理
sql加载数据库驱动
谁有人民日报数据库
维斯塔斯服务器密码
在制品管理软件开发
有软件正在使用数据库
《网络技术应用》全套教案
马勇康 网络安全
昆明一闻网络技术有限公司
软件开发外包服务实施方案
网络安全宣传周公安局
安全狗安装到云服务器
上饶金泉网络技术有限公司
湖湘杯网络安全技能大赛获奖名单
浙江服务器机柜哪个好
如何构建村庄数据库
网络安全设备测试拓扑
猪病数据库
数据库自动保存权限