Case Statement results based on another field










-1















Im trying to create a case statement to only show the value of AmountRequested based on the value in MortgageStatus
Basically if the MortgageStatus = 4 or 5 or 6 or 7 then i want to see the value of AmountRequested else show me 0



SELECT s.ISDESC as Source,
p.ClientId,p.Id AS [Profile ID],c.CaseTypeDesc As [Case Type],u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [Mortgage status] ,
CASE pm.AmountRequested
WHEN pm.MortgageStatus IN (4,5,6,7) THEN pm.AmountRequested
Else '0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,t.DueDate as [Enquiry Date],s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID


Thanks










share|improve this question

















  • 1





    So what's the problem?

    – Martin
    Nov 15 '18 at 11:15











  • Case expression results based on another column...'

    – jarlh
    Nov 15 '18 at 11:32















-1















Im trying to create a case statement to only show the value of AmountRequested based on the value in MortgageStatus
Basically if the MortgageStatus = 4 or 5 or 6 or 7 then i want to see the value of AmountRequested else show me 0



SELECT s.ISDESC as Source,
p.ClientId,p.Id AS [Profile ID],c.CaseTypeDesc As [Case Type],u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [Mortgage status] ,
CASE pm.AmountRequested
WHEN pm.MortgageStatus IN (4,5,6,7) THEN pm.AmountRequested
Else '0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,t.DueDate as [Enquiry Date],s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID


Thanks










share|improve this question

















  • 1





    So what's the problem?

    – Martin
    Nov 15 '18 at 11:15











  • Case expression results based on another column...'

    – jarlh
    Nov 15 '18 at 11:32













-1












-1








-1








Im trying to create a case statement to only show the value of AmountRequested based on the value in MortgageStatus
Basically if the MortgageStatus = 4 or 5 or 6 or 7 then i want to see the value of AmountRequested else show me 0



SELECT s.ISDESC as Source,
p.ClientId,p.Id AS [Profile ID],c.CaseTypeDesc As [Case Type],u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [Mortgage status] ,
CASE pm.AmountRequested
WHEN pm.MortgageStatus IN (4,5,6,7) THEN pm.AmountRequested
Else '0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,t.DueDate as [Enquiry Date],s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID


Thanks










share|improve this question














Im trying to create a case statement to only show the value of AmountRequested based on the value in MortgageStatus
Basically if the MortgageStatus = 4 or 5 or 6 or 7 then i want to see the value of AmountRequested else show me 0



SELECT s.ISDESC as Source,
p.ClientId,p.Id AS [Profile ID],c.CaseTypeDesc As [Case Type],u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [Mortgage status] ,
CASE pm.AmountRequested
WHEN pm.MortgageStatus IN (4,5,6,7) THEN pm.AmountRequested
Else '0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,t.DueDate as [Enquiry Date],s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID


Thanks







sql tsql case case-statement






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 15 '18 at 11:11









RustyHamsterRustyHamster

149215




149215







  • 1





    So what's the problem?

    – Martin
    Nov 15 '18 at 11:15











  • Case expression results based on another column...'

    – jarlh
    Nov 15 '18 at 11:32












  • 1





    So what's the problem?

    – Martin
    Nov 15 '18 at 11:15











  • Case expression results based on another column...'

    – jarlh
    Nov 15 '18 at 11:32







1




1





So what's the problem?

– Martin
Nov 15 '18 at 11:15





So what's the problem?

– Martin
Nov 15 '18 at 11:15













Case expression results based on another column...'

– jarlh
Nov 15 '18 at 11:32





Case expression results based on another column...'

– jarlh
Nov 15 '18 at 11:32












1 Answer
1






active

oldest

votes


















1














I think CASE syntax is incorrect. try this:



 SELECT s.ISDESC as Source,
p.ClientId,
p.Id AS [ Profile ID ],
c.CaseTypeDesc As [ Case Type ],
u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [ Mortgage status ],
CASE WHEN pm.MortgageStatus IN (4, 5, 6, 7) THEN
pm.AmountRequested
Else
'0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,
t.DueDate as [ Enquiry Date ],
s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID





share|improve this answer























  • Great thanks worked a treat

    – RustyHamster
    Nov 15 '18 at 11:35










Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53318181%2fcase-statement-results-based-on-another-field%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









1














I think CASE syntax is incorrect. try this:



 SELECT s.ISDESC as Source,
p.ClientId,
p.Id AS [ Profile ID ],
c.CaseTypeDesc As [ Case Type ],
u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [ Mortgage status ],
CASE WHEN pm.MortgageStatus IN (4, 5, 6, 7) THEN
pm.AmountRequested
Else
'0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,
t.DueDate as [ Enquiry Date ],
s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID





share|improve this answer























  • Great thanks worked a treat

    – RustyHamster
    Nov 15 '18 at 11:35















1














I think CASE syntax is incorrect. try this:



 SELECT s.ISDESC as Source,
p.ClientId,
p.Id AS [ Profile ID ],
c.CaseTypeDesc As [ Case Type ],
u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [ Mortgage status ],
CASE WHEN pm.MortgageStatus IN (4, 5, 6, 7) THEN
pm.AmountRequested
Else
'0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,
t.DueDate as [ Enquiry Date ],
s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID





share|improve this answer























  • Great thanks worked a treat

    – RustyHamster
    Nov 15 '18 at 11:35













1












1








1







I think CASE syntax is incorrect. try this:



 SELECT s.ISDESC as Source,
p.ClientId,
p.Id AS [ Profile ID ],
c.CaseTypeDesc As [ Case Type ],
u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [ Mortgage status ],
CASE WHEN pm.MortgageStatus IN (4, 5, 6, 7) THEN
pm.AmountRequested
Else
'0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,
t.DueDate as [ Enquiry Date ],
s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID





share|improve this answer













I think CASE syntax is incorrect. try this:



 SELECT s.ISDESC as Source,
p.ClientId,
p.Id AS [ Profile ID ],
c.CaseTypeDesc As [ Case Type ],
u.FullName AS Advisor,
ISNULL(app.StatusDesc, ' No contact') as [ Mortgage status ],
CASE WHEN pm.MortgageStatus IN (4, 5, 6, 7) THEN
pm.AmountRequested
Else
'0'
END,
em.Description,
pm.ProcFeeExp,
pm.ArrangementFee,
t.DueDate as [ Enquiry Date ],
s.ISDESC
From Tasks AS t
LEFT JOIN dbo.tbl_Profile AS p
ON t.FK_ProfileId = p.ID
LEFT JOIN dbo.tbl_CaseTypes AS c
ON c.CaseTypeID = p.CaseTypeID
LEFT JOIN dbo.tbl_User AS u
ON u.UserId = t.takenBy
LEFT JOIN tbl_Profile_Mortgage AS pm
ON p.Id = pm.FK_ProfileId
LEFT JOIN tbl_AppStatus AS app
ON pm.MortgageStatus = app.StatusId
LEFT JOIN tbl_DDEnquiryMethod AS em
ON t.EnquiryMethod = em.id
LEFT JOIN dbo.tbl_EnquiryType AS e
ON t.EnquiryType = e.EnquirytypeId
LEFT JOIN tbl_DDInitialSource as s
On t.EnquirySource = s.ISID






share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 15 '18 at 11:18









irakliG.irakliG.

1669




1669












  • Great thanks worked a treat

    – RustyHamster
    Nov 15 '18 at 11:35

















  • Great thanks worked a treat

    – RustyHamster
    Nov 15 '18 at 11:35
















Great thanks worked a treat

– RustyHamster
Nov 15 '18 at 11:35





Great thanks worked a treat

– RustyHamster
Nov 15 '18 at 11:35



















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53318181%2fcase-statement-results-based-on-another-field%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







這個網誌中的熱門文章

Barbados

How to read a connectionString WITH PROVIDER in .NET Core?

Node.js Script on GitHub Pages or Amazon S3