sql left join on查询条件不起作用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql left join on查询条件不起作用相关的知识,希望对你有一定的参考价值。

select tain.id as id,tain.name as name,tain.year as year,
tain.service_Nature as serviceNature,
tain.operate_Mode as operateMode,
stuff(
(select '+'+ltrim(pade.FK_NAME) from T_IA_PACKAGED_DETAIL pade
where pade.FK_TYPE='01'
and pade.TASK_ID =tain.ID for xml path('')
),1,1,'' <-----两个单引号
) as custNames,
stuff(
(select '+'+ltrim(pade.FK_NAME) from T_IA_PACKAGED_DETAIL pade
where pade.FK_TYPE='02'
and pade.TASK_ID =tain.ID for xml path('')
),1,1,'' <-----两个单引号
) as inkiNames
from T_IA_TASK_INFO tain LEFT JOIN
T_IA_PACKAGED_DETAIL pade ON
tain.year is null
......
ON后面的条件不起作用,楼下的说的都没错。我想问,是不是我用了left join ,第一个表里所有的数据会不会无条件的都查出来。如果我不用,就会多出很多重复的记录。总之,我想把tain.year is null等与表T_IA_PACKAGED_DETAIL 无关的条件加进去,又不想有重复的记录。该如何实现

tain.year is null
这一句应该放到where查询条件中,而不应该做为连接条件,连接条件应该是能关联两个表的列,你如果用tain.year is null 作为条件,系统会找出T_IA_TASK_INFO中所有year字段为Null的行,然后将这些行与表T_IA_PACKAGED_DETAIL中的行进行“全”连接(full),而year不为null的行,则不执行连接操作,因为系统没办法为这些行找到合适的连接条件,自然表T_IA_PACKAGED_DETAIL中也就没有满足条件的数据。所以你从结果上看,貌似是ON没有起作用。
参考技术A on 关联关系控制,符合条件的填充记录,不符合的补NULL
where 记录显示控制

楼主的在where 加上控制就可以实现了!
参考技术B 看的出来 这里需要的 是两个表的关联条件 而不是一个表的查询条件
tain.year is null 一般是 select * from T_IA_TASK_INFO tain where tain.year is null

而联表一般是这样的 select * from A LEFT JOIN B on A.id =B.aid
参考技术C tain.year is null
改为
pade.year is null

这才是left join 用法
条件为tain.year is null 时,要用 right join
参考技术D on 后面是连接条件,而不能当做查询条件

c# Linq left join 多个条件连接查询

如下面的sql 用查询表达式怎么写?
SELECT A.*,B.ITEM_NAME AS MoneyType_DESC,C.ITEM_NAME AS PayMentType_DESC,D.ITEM_NAME AS ApplyType_DESC
FROM DFZFORMT055 A
LEFT JOIN FM_CODE_LIST B ON A.MoneyType = B.ITEM_VALUE AND B.FORM_KIND = 'DFZ.FORM.T055' AND B.FIELD_NAME= 'MoneyType'
LEFT JOIN FM_CODE_LIST C ON A.PayMentType = C.ITEM_VALUE AND C.FORM_KIND = 'DFZ.FORM.T055' AND C.FIELD_NAME= 'PayMentType'
LEFT JOIN FM_CODE_LIST D ON A.APPLYTYPE = D.ITEM_VALUE AND D.FORM_KIND = 'DFZ.FORM.T055' AND D.FIELD_NAME= 'ApplyType'
WHERE A.form_no=9
自己搞定了,还是要谢谢 w362435819和 fansui1983
var query = from MainTable in T055
join B in (from codelist in CODELIST where codelist.FORM_KIND=="DFZ.FORM.T055" &&codelist.ITEM_NAME=="MoneyType" select codelist)
on MainTable.MoneyType equals B.ITEM_VALUE into B_Join
from BB in B_Join.DefaultIfEmpty()
join C in (from codelist in CODELIST2 where codelist.FORM_KIND == "DFZ.FORM.T055" && codelist.ITEM_NAME == "PayMentType" select codelist)
on MainTable.PayMentType equals C.ITEM_VALUE into C_Join
from CC in C_Join.DefaultIfEmpty()
join D in ....
where MainTable.FORM_NO == m_intFormNo

参考技术A 这代码看的晕啊....
一般 linq 连接用的是 from a in A jion b in B on ....条件
外连接用的是 from a in A jion b in B on ....条件 into C from a in C.DefaultIfEmpty()
参考技术B from A in DFZFORMT055 join B in FM_CODE_LIST on
A.MoneyType = B.ITEM_VALUE AND B.FORM_KIND = 'DFZ.FORM.T055' AND B.FIELD_NAME= 'MoneyType'
join C in JOIN FM_CODE_LIST on
A.PayMentType = C.ITEM_VALUE AND C.FORM_KIND = 'DFZ.FORM.T055' AND C.FIELD_NAME= 'PayMentType'

join D in FM_CODE_LIST on
A.APPLYTYPE = D.ITEM_VALUE AND D.FORM_KIND = 'DFZ.FORM.T055' AND D.FIELD_NAME= 'ApplyType'

where A.form_no=9
select A追问

不行,报错。DFZFORMT055为主表,FM_CODE_LIST为下拉菜单的数据存储表,以FORM_KIND,FIELD_NAME两栏位确定是那一下拉菜单的数据,ITEM_NAME,ITEM_VALUE为下拉菜单的值和显示名。
请表栏位:MoneyType ,PayMentType ,APPLYTYPE 为存储拉菜单值,但不一定会存入,所以就用left join 查找主管中的数据及下拉菜单有储存值的数据名。写sql很简单实现,后来改成linq实现就绑手绑脚的,又找不到相关的资料,还请各位高手多多指点。

本回答被提问者和网友采纳

以上是关于sql left join on查询条件不起作用的主要内容,如果未能解决你的问题,请参考以下文章

sql中join on两个条件怎么写

JPA Left Join IS NULL条件不起作用

MySql 之 left join 查询结果

c# Linq left join 多个条件连接查询

SQL多表联合查询(LEFT JOIN)条件差异

SQL中 LEFT JOIN ON 条件的效率高低比较