sql server 语句!!!!!这个怎么写

来源:百度知道 编辑:UC知道 时间:2024/07/04 14:03:44
表一(表名:钱):
姓名 金额 附言
张三0 200 人好
张三1 405 不好啊
张三2 234 不知道
张三3 532 怎么行
张三4 56 好的
张三5 432 哈哈
表二(表名:体):
名称 体重 身高
张三9 70 170
张三2 54 154
张三3 63 176
张三4 52 163
张三5 67 189
张三6 64 182
张三7 35 149
张三8 45 190

想要的效果,表三(表名:交差合并):
姓名 金额 附言 体重 身高
张三0 200 人好 NULL NULL
张三1 405 不好啊 NULL NULL
张三2 234 不知道 54 154
张三3 532 怎么行 63 176
张三4 56 好的 52 163
张三5 432 哈哈 67 189
张三6 NULL NULL 64 182
张三7 NULL NULL 35 149
张三8 NULL NULL 45 190
张三9 NULL NULL 70 170
机器猫爱郭富城,你的回答不对 即使我把表二的名称改了 也不行 你的做法只是取了它们相同的部分 我是相同的和不同的部分都要 没有数据的就为空
我试了一句select * from 体 full join 钱 on 体.名称=钱.姓名
谁能续写,再把我的姓名和名称合并(肯定姓名为空时取名称,名称为空时取姓名)

还是没有满意答案啊!大家加油加油!!!!!!!!!

外联接。外联接可以是左向外联接、右向外联接或完整外部联接。
在 FROM 子句中指定外联接时,可以由下列几组关键字中的一组指定:
LEFT JOIN 或 LEFT OUTER JOIN。
左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
RIGHT JOIN 或 RIGHT OUTER JOIN。
右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
FULL JOIN 或 FULL OUTER JOIN。
完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行。内联接消除与另一个表中的任何行不匹配的行。而外联接会返回 FROM 子句中提到的至少一个表或视图的所有行,只要这些行符合任何 WHERE 或 HAVING 搜索条件。将检索通过左向外联接引用的左表的所有行,以及通过右向外联接引用的右表的所有行。完整外部联接中两个表的所有行都将返回
select * from 表一FULL OUTER join表二on表一.姓名=表二.姓名
你的表里面姓名是主键吧兄弟,那就这样写,
好运!

select * from 表一join表二on表一.姓名=表二.姓名
可以了,你的表二有问题有张三的那一列不是名称吧应该是姓名~改改就可以了

select * from 体 full join 钱 on 体.名称=钱.姓名 or 体.名称 not is null or 钱.姓名 not is null