2016-11-01 4 views
0

DN7ステートメントを見る。私はジョイントエリアに何かが足りないと思う。ケースステートメントと結合

ca.code = 128の場合、company.nameをcompanyテーブルから表示する必要があります。 または ca.codeが106の場合、キャリア名が表示されます。
他ph.name

--TRANSACATION INFO FOR HT 
'148' as 'DN1', --TRANSACTION SET ID 
isnull(convert(char(2), d9.code), space(2)) as 'D2', --MAINTENANCE TYPE CODE 
isnull(left(convert(char(8), c2.froimaintdate, 112), 8), space(8)) as 'DN3c', ---MAINTENANCE TYPE CODE DATE 

--STATE AGENCY 
left(c1.jurst, 2) as 'DN4', --Jurisdiction Code 
isnull(convert(char(25), c1.agencynumb), space(25)) as 'DN5', --Claim Number 

--INSURER/CARRIER/SELF-INSURER 
case 
    when ca.invmsg like 'CARRIER%' then isnull(left(uw.fedid, 9), space(9)) 
    else left(ph.fedid, 9) 
end 
as 'DN6', --Carrier/Self-Insurer FEIN 
case 
    when ca.invmsg like 'CARRIER%' and ca.code ='0128' then isnull(convert(char(30), (ca.name)), space(30)) 
    when ca.invmsg like 'CARRIER%' and ca.code ='0106' then isnull(convert(char(30), (uw.name)), space(30)) 
    else convert(char(30), (ph.name)) 
end 
as 'DN7', --Carrier/Self-Insurer Name** 

    from claim c 
join claim1 c1 on c.claimno = c1.lnkclaimno 
join claim2 c2 on c.claimno = c2.link2claim 
join claim3 c3 on c.claimno = c3.link3claim 
join person p on c.patient = p.personid 
join employer e on c.empcode = e.code 
join cmpolicy cm on c.claimno = cm.claimno 
join policy po on cm.policyid = po.policyid 
join carrier ca on c.carrier = ca.code 
join masttype m on c.casetype = m.mastid 
left join company uw on po.uwcompany = uw.code 
left join [address] a on c.occurlocat = a.addrid 
left join employer ph on e.polholder = ph.code 
left join mmi1 mm on c.claimno = mm.claimno 
left join dictdata d1 on ph.siccode = d1.datumid  --SIC Code 
left join dictdata d2 on c2.claimncci = d2.datumid  --NCCI Class (Occ) Code 
left join dictdata d3 on c1.injurnatur = d3.datumid  --Nature of Injury 
left join dictdata d4 on c.bodypartid = d4.datumid  --Body Part 
left join dictdata d5 on c1.injurcause = d5.datumid  --Cause of Injury 
left join dictdata d6 on c1.empstatus = d6.datumid  --Employment Status 
left join dictdata d7 on c2.losstype = d7.datumid  --Type Of Loss Code 
left join dictdata d8 on c2.mcotype = d8.datumid  --Managed Care Organization Code 
left join dictdata d9 on c2.froimaintcode = d9.datumid --Maintenance Type Code 
left join authent au on c1.adjuster = au.shortname  --Adjuster 
left join usermst u on au.authentid = u.personid  --Adjuster 
left join authent au2 on c.username = au2.shortname  --User (Preparer) 
left join usermst u2 on au2.authentid = u2.personid  --User (Preparer) 
left join provider pv on c3.treatprovider = pv.fedidseq --Initial Treatment Provider 
left join v_provaddr_master v on pv.fedidseq = v.fedidseq --Initial Treatment Provider Address 
left join cf_data cf1 on c.claimno = cf1.claimno and cf1.cf_id = '00024' --Notice Date 


--Date Function 
WHERE froimaintdate = '2016-10-26' 
     and c1.jurst = 'TX' 
+0

は、コード番号0128か128か数値かvarcharですか。会社名を106に、キャリア名を106にしたいと言うと、なぜ両方の行にuw.nameを使用していますか?ここではあまりにも多くの未知数。質の高い応答を提供する。 – xQbert

+0

0128および0106 char値。はい、会社名が0128の場合はキャリア名、値が106の場合 – Dizzle

+0

「0106」を示す行で 'uw.name'を' ca.name'に変更するだけですか?それはあなたが両方の行に会社名を表示しているようだ。私はcarrierNameがキャリアテーブルから供給されると仮定します。 – xQbert

答えて

0

あなたは106のための搬送ライン上の間違ったテーブルの別名を持っているように私には見える...を選択代わりにUWのCAを使用できますか?

case 
    when ca.invmsg like 'CARRIER%' and ca.code ='0128' then isnull(convert(char(30), (uw.name)), space(30)) 
    when ca.invmsg like 'CARRIER%' and ca.code ='0106' then isnull(convert(char(30), (ca.name)), space(30)) 
    else convert(char(30), (ph.name)) 
end 
as 'DN7', --Carrier/Self-Insurer Name** 

は、私はまた、そうでなければ、最後に,をぶら下げているD7の後に複数のフィールドがありますと仮定します。

---参加が不良データによる失敗しているので、あなたがNULLのレコードを取得するか

SELECT C.ClaimNo as C_ClaimNo, CM.ClaimNo as CM_ClaimNo, 
C.Carrier as C_Carrier, CA.Code as CA_Carrier, 
PO.PolicyID as PO_Policy_ID, CM.PolicyID as CM_PolicyID, 
UW.Code as UW_Company, PO.UWCompany as PO_UWCompany, 
CA.Name as CA_Name, Uw.Name as UW_Name, PH.Name as PH_Name 

from claim c 
join claim1 c1 on c.claimno = c1.lnkclaimno 
join claim2 c2 on c.claimno = c2.link2claim 
join claim3 c3 on c.claimno = c3.link3claim 
join person p on c.patient = p.personid 
join employer e on c.empcode = e.code 
join cmpolicy cm on c.claimno = cm.claimno 
join policy po on cm.policyid = po.policyid 
join carrier ca on c.carrier = ca.code 
join masttype m on c.casetype = m.mastid 
left join company uw on po.uwcompany = uw.code 
left join [address] a on c.occurlocat = a.addrid 
left join employer ph on e.polholder = ph.code 
WHERE C.ClaimNo = 'SomeVaule you're not getting resutls for' 

...問題がどこにある視覚化を支援するために、これを試してみてください。 または、悪いデータのために左側の結合の1つで再びnull値を取得します。 または、実際には空白なので、CA_Nameにnull値が返されます。

+0

例をca.codeに変更しましたが、実際には雇用主のテーブルから抜け出しています。 – Dizzle

+0

ジョインの名前に基づいて、それらはうまく見えます。あなたにはデータ問題がいくつかあるように見えます。おそらく左端またはその近くで企業に参加する可能性があります。したがって、po.uwcompanyはあなたがこの会社に期待しているものではないか、comapnyテーブルに記録がありません。これを理解するには、この問題を示すサンプルデータのモックアップを見る必要があります。コードが "見える"ように立つので、うまくいく。しかし、一般的な名前だけに基づいて、私はテーブルのDDLを参照する必要はないでしょう。テーブル間のPK/FK関係はありません。 – xQbert

+0

私は問題がどこにあるかを知るために、問題が発生している特定のクレームにwhere節を変更して実行します(コメントとして長すぎると答えるために追加されました) – xQbert

関連する問題