“mysql ”多表联合查询语句怎么写?

“mysql ”多表联合查询语句怎么写?,第1张

一使用SELECT子句进行多表查询SELECT 字段名 FROM 表1,表2 … WHERE 表1字段 = 表2字段 AND 其它查询条件SELECT a.id,a.name,a.address,a.date,b.math,b.english,b.chinese FROM tb_demo065_tel AS b,tb_demo065 AS a WHERE a.id=b.id

注:在上面的的代码中,以两张表的id字段信息相同作为条件建立两表关联,但在实际开发中不应该这样使用,最好用主外键约束来实现。

1、联合查询可合并多个相似的选择查询的结果集。等同于将一个表追加到另一个表,从而实现将两个表的查询组合到一起,使用谓词为UNION或UNION ALL。联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。

2、在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类型,系统将低精度的数据类型转换为高精度的数据类型。

3、在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如:查询1 UNION (查询2 UNION 查询3)。

1.合并的第一个步骤,是在修改【表1】结构,增加【经验值】列,可以写SQL,也可以在管理界面点鼠标完成。

2.合并的第二个步骤,是把【表1】现有数据的经验值更新,SQL语句:

UPDATE 表1 SET 经验值=(SELECT 经验值 FROM 表2 WHERE 表1.姓名=表2.姓名

3.合并的第三个步骤,把【表2】中剩下的数据复制到【表1】中,SQL语句:

DELETE FROM 表2 WHERE 姓名 IN (SELECT 姓名 FROM 表1)

INSERT INTO 表1(姓名,经验值) SELECT 姓名,经验值 FROM 表2

SELECT * FROM 表1

INNER JOIN 表2 ON 表1.共有字段 = 表2.共有字段

INNER JOIN 表3 ON 表1.共有字段 = 表3.共有字段

...


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/6166945.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-17
下一篇 2023-03-17

发表评论

登录后才能评论

评论列表(0条)

保存