T-sql select statement - multiple column with Case statement yes or no based on another table data
I have a T-SQL select
statement with multiple columns with Case
statements yes or no based on another table data
I have these two tables:
table1
Id | Location
----+------------
101 | Warsaw
102 | Belfast
104 | Singapore
106 | Texas
108 | Mumbai
109 | Virgina
table2:
Id | AttrName | AttrId
----+------------+---------
101 | Datacenter | 99
101 | Cold | 88
102 | Datacenter | 99
102 | Cold | 88
106 | Datacenter | 99
108 | Cold | 88
The query output should be:
Id | Location | Datacenter | Cold
----+-----------+------------+------
101 | Warsaw | YES | YES
102 | Belfast | YES | YES
104 | Singapore | NO | NO
106 | Texas | YES | NO
108 | Mumbai | NO | YES
109 | Virgina | NO | NO
Please let me know how we can achieve this.
sql-server tsql
add a comment |
I have a T-SQL select
statement with multiple columns with Case
statements yes or no based on another table data
I have these two tables:
table1
Id | Location
----+------------
101 | Warsaw
102 | Belfast
104 | Singapore
106 | Texas
108 | Mumbai
109 | Virgina
table2:
Id | AttrName | AttrId
----+------------+---------
101 | Datacenter | 99
101 | Cold | 88
102 | Datacenter | 99
102 | Cold | 88
106 | Datacenter | 99
108 | Cold | 88
The query output should be:
Id | Location | Datacenter | Cold
----+-----------+------------+------
101 | Warsaw | YES | YES
102 | Belfast | YES | YES
104 | Singapore | NO | NO
106 | Texas | YES | NO
108 | Mumbai | NO | YES
109 | Virgina | NO | NO
Please let me know how we can achieve this.
sql-server tsql
Please read this for some tips on improving your question. And why thesp
tag?
– HABO
Nov 14 '18 at 23:22
3
StackOverflow is not a code or SQL writing service. We expect you to make an effort to solve the problem yourself first. Once you've done so and run into difficulties, you can explain what you're trying to do and the problem you're having, include the relevant portions of your code, and ask a specific question related to that code, and we'll be glad to try to help. Your experiences here will be much better if you spend some time taking the tour and reading the help center pages, especially How to Ask, before you begin posting here.
– Ken White
Nov 14 '18 at 23:38
This is the query I have tried in isql and it worked. I'm working to accomplish in mssql. select a.id, a.Location,'Datacenter' =case when b1.AttrId=99 then 'yes' else 'No' end,'Cold'=case when b2.AttrId=88 then 'yes' else 'No' end from table1 a, (select Id,AttrId from table2 b where AttrId=99) b1, (select Id,AttrId from table2 b where AttrId=88) b2 where a.Id*=b1.Id and a.Id*=b2.Id
– MTC Entertainment
Nov 15 '18 at 12:27
add a comment |
I have a T-SQL select
statement with multiple columns with Case
statements yes or no based on another table data
I have these two tables:
table1
Id | Location
----+------------
101 | Warsaw
102 | Belfast
104 | Singapore
106 | Texas
108 | Mumbai
109 | Virgina
table2:
Id | AttrName | AttrId
----+------------+---------
101 | Datacenter | 99
101 | Cold | 88
102 | Datacenter | 99
102 | Cold | 88
106 | Datacenter | 99
108 | Cold | 88
The query output should be:
Id | Location | Datacenter | Cold
----+-----------+------------+------
101 | Warsaw | YES | YES
102 | Belfast | YES | YES
104 | Singapore | NO | NO
106 | Texas | YES | NO
108 | Mumbai | NO | YES
109 | Virgina | NO | NO
Please let me know how we can achieve this.
sql-server tsql
I have a T-SQL select
statement with multiple columns with Case
statements yes or no based on another table data
I have these two tables:
table1
Id | Location
----+------------
101 | Warsaw
102 | Belfast
104 | Singapore
106 | Texas
108 | Mumbai
109 | Virgina
table2:
Id | AttrName | AttrId
----+------------+---------
101 | Datacenter | 99
101 | Cold | 88
102 | Datacenter | 99
102 | Cold | 88
106 | Datacenter | 99
108 | Cold | 88
The query output should be:
Id | Location | Datacenter | Cold
----+-----------+------------+------
101 | Warsaw | YES | YES
102 | Belfast | YES | YES
104 | Singapore | NO | NO
106 | Texas | YES | NO
108 | Mumbai | NO | YES
109 | Virgina | NO | NO
Please let me know how we can achieve this.
sql-server tsql
sql-server tsql
edited Nov 15 '18 at 5:23
marc_s
579k12911181265
579k12911181265
asked Nov 14 '18 at 23:17
MTC EntertainmentMTC Entertainment
1
1
Please read this for some tips on improving your question. And why thesp
tag?
– HABO
Nov 14 '18 at 23:22
3
StackOverflow is not a code or SQL writing service. We expect you to make an effort to solve the problem yourself first. Once you've done so and run into difficulties, you can explain what you're trying to do and the problem you're having, include the relevant portions of your code, and ask a specific question related to that code, and we'll be glad to try to help. Your experiences here will be much better if you spend some time taking the tour and reading the help center pages, especially How to Ask, before you begin posting here.
– Ken White
Nov 14 '18 at 23:38
This is the query I have tried in isql and it worked. I'm working to accomplish in mssql. select a.id, a.Location,'Datacenter' =case when b1.AttrId=99 then 'yes' else 'No' end,'Cold'=case when b2.AttrId=88 then 'yes' else 'No' end from table1 a, (select Id,AttrId from table2 b where AttrId=99) b1, (select Id,AttrId from table2 b where AttrId=88) b2 where a.Id*=b1.Id and a.Id*=b2.Id
– MTC Entertainment
Nov 15 '18 at 12:27
add a comment |
Please read this for some tips on improving your question. And why thesp
tag?
– HABO
Nov 14 '18 at 23:22
3
StackOverflow is not a code or SQL writing service. We expect you to make an effort to solve the problem yourself first. Once you've done so and run into difficulties, you can explain what you're trying to do and the problem you're having, include the relevant portions of your code, and ask a specific question related to that code, and we'll be glad to try to help. Your experiences here will be much better if you spend some time taking the tour and reading the help center pages, especially How to Ask, before you begin posting here.
– Ken White
Nov 14 '18 at 23:38
This is the query I have tried in isql and it worked. I'm working to accomplish in mssql. select a.id, a.Location,'Datacenter' =case when b1.AttrId=99 then 'yes' else 'No' end,'Cold'=case when b2.AttrId=88 then 'yes' else 'No' end from table1 a, (select Id,AttrId from table2 b where AttrId=99) b1, (select Id,AttrId from table2 b where AttrId=88) b2 where a.Id*=b1.Id and a.Id*=b2.Id
– MTC Entertainment
Nov 15 '18 at 12:27
Please read this for some tips on improving your question. And why the
sp
tag?– HABO
Nov 14 '18 at 23:22
Please read this for some tips on improving your question. And why the
sp
tag?– HABO
Nov 14 '18 at 23:22
3
3
StackOverflow is not a code or SQL writing service. We expect you to make an effort to solve the problem yourself first. Once you've done so and run into difficulties, you can explain what you're trying to do and the problem you're having, include the relevant portions of your code, and ask a specific question related to that code, and we'll be glad to try to help. Your experiences here will be much better if you spend some time taking the tour and reading the help center pages, especially How to Ask, before you begin posting here.
– Ken White
Nov 14 '18 at 23:38
StackOverflow is not a code or SQL writing service. We expect you to make an effort to solve the problem yourself first. Once you've done so and run into difficulties, you can explain what you're trying to do and the problem you're having, include the relevant portions of your code, and ask a specific question related to that code, and we'll be glad to try to help. Your experiences here will be much better if you spend some time taking the tour and reading the help center pages, especially How to Ask, before you begin posting here.
– Ken White
Nov 14 '18 at 23:38
This is the query I have tried in isql and it worked. I'm working to accomplish in mssql. select a.id, a.Location,'Datacenter' =case when b1.AttrId=99 then 'yes' else 'No' end,'Cold'=case when b2.AttrId=88 then 'yes' else 'No' end from table1 a, (select Id,AttrId from table2 b where AttrId=99) b1, (select Id,AttrId from table2 b where AttrId=88) b2 where a.Id*=b1.Id and a.Id*=b2.Id
– MTC Entertainment
Nov 15 '18 at 12:27
This is the query I have tried in isql and it worked. I'm working to accomplish in mssql. select a.id, a.Location,'Datacenter' =case when b1.AttrId=99 then 'yes' else 'No' end,'Cold'=case when b2.AttrId=88 then 'yes' else 'No' end from table1 a, (select Id,AttrId from table2 b where AttrId=99) b1, (select Id,AttrId from table2 b where AttrId=88) b2 where a.Id*=b1.Id and a.Id*=b2.Id
– MTC Entertainment
Nov 15 '18 at 12:27
add a comment |
3 Answers
3
active
oldest
votes
I'd use PIVOT instead. It can perform better, but I'd check the execution plans on each to be sure. Just be sure to redirect my query to the real tables (instead of these table variables for testing) before you compare plans. Good luck! :)
DECLARE @Table1 TABLE (
Id BIGINT NOT NULL PRIMARY KEY,
Location VARCHAR(100) NOT NULL,
UNIQUE CLUSTERED (Id)
);
INSERT INTO @Table1
(Id, Location)
VALUES
(101,'Warsaw'),
(102,'Belfast'),
(104,'Singapore'),
(106,'Texas'),
(108,'Mumbai'),
(109,'Virgina');
DECLARE @Table2 TABLE (
Id BIGINT NOT NULL,
AttrName VARCHAR(100) NOT NULL,
AttrId BIGINT NOT NULL,
UNIQUE CLUSTERED (Id,AttrId)
);
INSERT INTO @Table2
(Id, AttrName, AttrId)
VALUES
(101,'Datacenter',99),
(101,'Cold',88),
(102,'Datacenter',99),
(102,'Cold',88),
(106,'Datacenter',99),
(108,'Cold',88);
WITH CTE_Table2 AS (
SELECT
Id,
Datacenter,
Cold
FROM (
SELECT
t.Id,
t.AttrName,
'YES' AS Bool
FROM @Table2 AS t
) AS b
PIVOT (
MAX(Bool)
FOR AttrName IN ([Datacenter],[Cold])
) AS p
)
SELECT
t1.Id,
t1.Location,
ISNULL(t2.Datacenter,'NO') AS Datacenter,
ISNULL(t2.Cold,'NO') AS Cold
FROM @Table1 AS t1
LEFT JOIN CTE_Table2 AS t2
ON t1.Id = t2.Id;
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
add a comment |
Below is other option to resolve, it uses EXISTS
,
-- delcare table variables
declare @t1 table (Id int, Location nvarchar(20))
declare @t2 table (Id int, AttrName nvarchar(20), AttrId int)
-- insert test data
insert into @t1
values (101, 'Warsaw'),
(102, 'Beflast'),
(104, 'Singapore'),
(106, 'Texas'),
(108, 'Mumbai'),
(109, 'Virginia')
insert into @t2
values (101, 'Datacentre', 99),
(101, 'Cold', 88),
(102, 'Datacentre', 99),
(102, 'Cold', 88),
(106, 'Datacentre', 99),
(108, 'Cold', 88)
-- query
select
t1.Id,
Location,
case when exists (select 1 from @t2 t2 where t2.AttrId = 99 and t1.id = t2.id) then 'yes' else 'no' end as Datacentre,
case when exists (select 1 from @t2 t2 where t2.AttrId = 88 and t1.id = t2.id) then 'yes' else 'no' end as Cold
from @t1 t1
Result
Id Location Datacentre Cold
101 Warsaw yes yes
102 Beflast yes yes
104 Singapore no no
106 Texas yes no
108 Mumbai no yes
109 Virginia no no
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
add a comment |
- Simple but not optimized approach: You need to LEFT OUTER JOIN table2 to table1 as many times as many AttrName's you would like to put in different columns in the final result. Each join should use a different alias name for table2 and filter on a specific AttrName:
FROM table1 as base
LEFT OUTER JOIN table2 as Datacenter on base.Id = Datacenter.Id and Datacenter.AttrName = 'Datacenter'
LEFT OUTER JOIN table2 as Cold on base.Id = Cold.Id and Cold.AttrName = 'Cold'
In the SELECT you need to check for the existence of matching lookup to the specific alias of table2 to define a column deriving from AttrName:
CASE WHEN Datacenter.Id IS NOT NULL THEN 'YES' ELSE 'NO' END as Datacenter
- Advanced and likely more optimized approach:
Use Utrolig's answer: PIVOT should outperform due to less lookups (but always look at query plans when you optimize code!)
add a comment |
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
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53310200%2ft-sql-select-statement-multiple-column-with-case-statement-yes-or-no-based-on%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
3 Answers
3
active
oldest
votes
3 Answers
3
active
oldest
votes
active
oldest
votes
active
oldest
votes
I'd use PIVOT instead. It can perform better, but I'd check the execution plans on each to be sure. Just be sure to redirect my query to the real tables (instead of these table variables for testing) before you compare plans. Good luck! :)
DECLARE @Table1 TABLE (
Id BIGINT NOT NULL PRIMARY KEY,
Location VARCHAR(100) NOT NULL,
UNIQUE CLUSTERED (Id)
);
INSERT INTO @Table1
(Id, Location)
VALUES
(101,'Warsaw'),
(102,'Belfast'),
(104,'Singapore'),
(106,'Texas'),
(108,'Mumbai'),
(109,'Virgina');
DECLARE @Table2 TABLE (
Id BIGINT NOT NULL,
AttrName VARCHAR(100) NOT NULL,
AttrId BIGINT NOT NULL,
UNIQUE CLUSTERED (Id,AttrId)
);
INSERT INTO @Table2
(Id, AttrName, AttrId)
VALUES
(101,'Datacenter',99),
(101,'Cold',88),
(102,'Datacenter',99),
(102,'Cold',88),
(106,'Datacenter',99),
(108,'Cold',88);
WITH CTE_Table2 AS (
SELECT
Id,
Datacenter,
Cold
FROM (
SELECT
t.Id,
t.AttrName,
'YES' AS Bool
FROM @Table2 AS t
) AS b
PIVOT (
MAX(Bool)
FOR AttrName IN ([Datacenter],[Cold])
) AS p
)
SELECT
t1.Id,
t1.Location,
ISNULL(t2.Datacenter,'NO') AS Datacenter,
ISNULL(t2.Cold,'NO') AS Cold
FROM @Table1 AS t1
LEFT JOIN CTE_Table2 AS t2
ON t1.Id = t2.Id;
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
add a comment |
I'd use PIVOT instead. It can perform better, but I'd check the execution plans on each to be sure. Just be sure to redirect my query to the real tables (instead of these table variables for testing) before you compare plans. Good luck! :)
DECLARE @Table1 TABLE (
Id BIGINT NOT NULL PRIMARY KEY,
Location VARCHAR(100) NOT NULL,
UNIQUE CLUSTERED (Id)
);
INSERT INTO @Table1
(Id, Location)
VALUES
(101,'Warsaw'),
(102,'Belfast'),
(104,'Singapore'),
(106,'Texas'),
(108,'Mumbai'),
(109,'Virgina');
DECLARE @Table2 TABLE (
Id BIGINT NOT NULL,
AttrName VARCHAR(100) NOT NULL,
AttrId BIGINT NOT NULL,
UNIQUE CLUSTERED (Id,AttrId)
);
INSERT INTO @Table2
(Id, AttrName, AttrId)
VALUES
(101,'Datacenter',99),
(101,'Cold',88),
(102,'Datacenter',99),
(102,'Cold',88),
(106,'Datacenter',99),
(108,'Cold',88);
WITH CTE_Table2 AS (
SELECT
Id,
Datacenter,
Cold
FROM (
SELECT
t.Id,
t.AttrName,
'YES' AS Bool
FROM @Table2 AS t
) AS b
PIVOT (
MAX(Bool)
FOR AttrName IN ([Datacenter],[Cold])
) AS p
)
SELECT
t1.Id,
t1.Location,
ISNULL(t2.Datacenter,'NO') AS Datacenter,
ISNULL(t2.Cold,'NO') AS Cold
FROM @Table1 AS t1
LEFT JOIN CTE_Table2 AS t2
ON t1.Id = t2.Id;
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
add a comment |
I'd use PIVOT instead. It can perform better, but I'd check the execution plans on each to be sure. Just be sure to redirect my query to the real tables (instead of these table variables for testing) before you compare plans. Good luck! :)
DECLARE @Table1 TABLE (
Id BIGINT NOT NULL PRIMARY KEY,
Location VARCHAR(100) NOT NULL,
UNIQUE CLUSTERED (Id)
);
INSERT INTO @Table1
(Id, Location)
VALUES
(101,'Warsaw'),
(102,'Belfast'),
(104,'Singapore'),
(106,'Texas'),
(108,'Mumbai'),
(109,'Virgina');
DECLARE @Table2 TABLE (
Id BIGINT NOT NULL,
AttrName VARCHAR(100) NOT NULL,
AttrId BIGINT NOT NULL,
UNIQUE CLUSTERED (Id,AttrId)
);
INSERT INTO @Table2
(Id, AttrName, AttrId)
VALUES
(101,'Datacenter',99),
(101,'Cold',88),
(102,'Datacenter',99),
(102,'Cold',88),
(106,'Datacenter',99),
(108,'Cold',88);
WITH CTE_Table2 AS (
SELECT
Id,
Datacenter,
Cold
FROM (
SELECT
t.Id,
t.AttrName,
'YES' AS Bool
FROM @Table2 AS t
) AS b
PIVOT (
MAX(Bool)
FOR AttrName IN ([Datacenter],[Cold])
) AS p
)
SELECT
t1.Id,
t1.Location,
ISNULL(t2.Datacenter,'NO') AS Datacenter,
ISNULL(t2.Cold,'NO') AS Cold
FROM @Table1 AS t1
LEFT JOIN CTE_Table2 AS t2
ON t1.Id = t2.Id;
I'd use PIVOT instead. It can perform better, but I'd check the execution plans on each to be sure. Just be sure to redirect my query to the real tables (instead of these table variables for testing) before you compare plans. Good luck! :)
DECLARE @Table1 TABLE (
Id BIGINT NOT NULL PRIMARY KEY,
Location VARCHAR(100) NOT NULL,
UNIQUE CLUSTERED (Id)
);
INSERT INTO @Table1
(Id, Location)
VALUES
(101,'Warsaw'),
(102,'Belfast'),
(104,'Singapore'),
(106,'Texas'),
(108,'Mumbai'),
(109,'Virgina');
DECLARE @Table2 TABLE (
Id BIGINT NOT NULL,
AttrName VARCHAR(100) NOT NULL,
AttrId BIGINT NOT NULL,
UNIQUE CLUSTERED (Id,AttrId)
);
INSERT INTO @Table2
(Id, AttrName, AttrId)
VALUES
(101,'Datacenter',99),
(101,'Cold',88),
(102,'Datacenter',99),
(102,'Cold',88),
(106,'Datacenter',99),
(108,'Cold',88);
WITH CTE_Table2 AS (
SELECT
Id,
Datacenter,
Cold
FROM (
SELECT
t.Id,
t.AttrName,
'YES' AS Bool
FROM @Table2 AS t
) AS b
PIVOT (
MAX(Bool)
FOR AttrName IN ([Datacenter],[Cold])
) AS p
)
SELECT
t1.Id,
t1.Location,
ISNULL(t2.Datacenter,'NO') AS Datacenter,
ISNULL(t2.Cold,'NO') AS Cold
FROM @Table1 AS t1
LEFT JOIN CTE_Table2 AS t2
ON t1.Id = t2.Id;
edited Nov 15 '18 at 8:51
answered Nov 15 '18 at 8:08
UtroligUtrolig
241211
241211
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
add a comment |
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
As an extra note here... the comments on your main post about putting in real effort is important. The only reason I'm helping in this case is because you're new to SO. It takes some getting used to. I hope my SQL can actually help your situation.
– Utrolig
Nov 15 '18 at 8:33
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Thank you. I have tried to update my comments with the query I have used before in isql ( it works) but in mssql it's not working. Also I want to update the query in my question, it's not allowing to update it( Format issue).
– MTC Entertainment
Nov 15 '18 at 12:25
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
Sorry @MTCEntertainment, does that mean this worked for you? Do you still need assistance?
– Utrolig
Nov 15 '18 at 17:19
add a comment |
Below is other option to resolve, it uses EXISTS
,
-- delcare table variables
declare @t1 table (Id int, Location nvarchar(20))
declare @t2 table (Id int, AttrName nvarchar(20), AttrId int)
-- insert test data
insert into @t1
values (101, 'Warsaw'),
(102, 'Beflast'),
(104, 'Singapore'),
(106, 'Texas'),
(108, 'Mumbai'),
(109, 'Virginia')
insert into @t2
values (101, 'Datacentre', 99),
(101, 'Cold', 88),
(102, 'Datacentre', 99),
(102, 'Cold', 88),
(106, 'Datacentre', 99),
(108, 'Cold', 88)
-- query
select
t1.Id,
Location,
case when exists (select 1 from @t2 t2 where t2.AttrId = 99 and t1.id = t2.id) then 'yes' else 'no' end as Datacentre,
case when exists (select 1 from @t2 t2 where t2.AttrId = 88 and t1.id = t2.id) then 'yes' else 'no' end as Cold
from @t1 t1
Result
Id Location Datacentre Cold
101 Warsaw yes yes
102 Beflast yes yes
104 Singapore no no
106 Texas yes no
108 Mumbai no yes
109 Virginia no no
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
add a comment |
Below is other option to resolve, it uses EXISTS
,
-- delcare table variables
declare @t1 table (Id int, Location nvarchar(20))
declare @t2 table (Id int, AttrName nvarchar(20), AttrId int)
-- insert test data
insert into @t1
values (101, 'Warsaw'),
(102, 'Beflast'),
(104, 'Singapore'),
(106, 'Texas'),
(108, 'Mumbai'),
(109, 'Virginia')
insert into @t2
values (101, 'Datacentre', 99),
(101, 'Cold', 88),
(102, 'Datacentre', 99),
(102, 'Cold', 88),
(106, 'Datacentre', 99),
(108, 'Cold', 88)
-- query
select
t1.Id,
Location,
case when exists (select 1 from @t2 t2 where t2.AttrId = 99 and t1.id = t2.id) then 'yes' else 'no' end as Datacentre,
case when exists (select 1 from @t2 t2 where t2.AttrId = 88 and t1.id = t2.id) then 'yes' else 'no' end as Cold
from @t1 t1
Result
Id Location Datacentre Cold
101 Warsaw yes yes
102 Beflast yes yes
104 Singapore no no
106 Texas yes no
108 Mumbai no yes
109 Virginia no no
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
add a comment |
Below is other option to resolve, it uses EXISTS
,
-- delcare table variables
declare @t1 table (Id int, Location nvarchar(20))
declare @t2 table (Id int, AttrName nvarchar(20), AttrId int)
-- insert test data
insert into @t1
values (101, 'Warsaw'),
(102, 'Beflast'),
(104, 'Singapore'),
(106, 'Texas'),
(108, 'Mumbai'),
(109, 'Virginia')
insert into @t2
values (101, 'Datacentre', 99),
(101, 'Cold', 88),
(102, 'Datacentre', 99),
(102, 'Cold', 88),
(106, 'Datacentre', 99),
(108, 'Cold', 88)
-- query
select
t1.Id,
Location,
case when exists (select 1 from @t2 t2 where t2.AttrId = 99 and t1.id = t2.id) then 'yes' else 'no' end as Datacentre,
case when exists (select 1 from @t2 t2 where t2.AttrId = 88 and t1.id = t2.id) then 'yes' else 'no' end as Cold
from @t1 t1
Result
Id Location Datacentre Cold
101 Warsaw yes yes
102 Beflast yes yes
104 Singapore no no
106 Texas yes no
108 Mumbai no yes
109 Virginia no no
Below is other option to resolve, it uses EXISTS
,
-- delcare table variables
declare @t1 table (Id int, Location nvarchar(20))
declare @t2 table (Id int, AttrName nvarchar(20), AttrId int)
-- insert test data
insert into @t1
values (101, 'Warsaw'),
(102, 'Beflast'),
(104, 'Singapore'),
(106, 'Texas'),
(108, 'Mumbai'),
(109, 'Virginia')
insert into @t2
values (101, 'Datacentre', 99),
(101, 'Cold', 88),
(102, 'Datacentre', 99),
(102, 'Cold', 88),
(106, 'Datacentre', 99),
(108, 'Cold', 88)
-- query
select
t1.Id,
Location,
case when exists (select 1 from @t2 t2 where t2.AttrId = 99 and t1.id = t2.id) then 'yes' else 'no' end as Datacentre,
case when exists (select 1 from @t2 t2 where t2.AttrId = 88 and t1.id = t2.id) then 'yes' else 'no' end as Cold
from @t1 t1
Result
Id Location Datacentre Cold
101 Warsaw yes yes
102 Beflast yes yes
104 Singapore no no
106 Texas yes no
108 Mumbai no yes
109 Virginia no no
edited Nov 15 '18 at 8:58
Dávid Laczkó
429128
429128
answered Nov 15 '18 at 8:33
Pawel CzapskiPawel Czapski
1,3371917
1,3371917
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
add a comment |
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
Thank you. let me try this.
– MTC Entertainment
Nov 15 '18 at 12:25
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
@MTCEntertainment, add comment if something is unclear.
– Pawel Czapski
Nov 15 '18 at 13:16
add a comment |
- Simple but not optimized approach: You need to LEFT OUTER JOIN table2 to table1 as many times as many AttrName's you would like to put in different columns in the final result. Each join should use a different alias name for table2 and filter on a specific AttrName:
FROM table1 as base
LEFT OUTER JOIN table2 as Datacenter on base.Id = Datacenter.Id and Datacenter.AttrName = 'Datacenter'
LEFT OUTER JOIN table2 as Cold on base.Id = Cold.Id and Cold.AttrName = 'Cold'
In the SELECT you need to check for the existence of matching lookup to the specific alias of table2 to define a column deriving from AttrName:
CASE WHEN Datacenter.Id IS NOT NULL THEN 'YES' ELSE 'NO' END as Datacenter
- Advanced and likely more optimized approach:
Use Utrolig's answer: PIVOT should outperform due to less lookups (but always look at query plans when you optimize code!)
add a comment |
- Simple but not optimized approach: You need to LEFT OUTER JOIN table2 to table1 as many times as many AttrName's you would like to put in different columns in the final result. Each join should use a different alias name for table2 and filter on a specific AttrName:
FROM table1 as base
LEFT OUTER JOIN table2 as Datacenter on base.Id = Datacenter.Id and Datacenter.AttrName = 'Datacenter'
LEFT OUTER JOIN table2 as Cold on base.Id = Cold.Id and Cold.AttrName = 'Cold'
In the SELECT you need to check for the existence of matching lookup to the specific alias of table2 to define a column deriving from AttrName:
CASE WHEN Datacenter.Id IS NOT NULL THEN 'YES' ELSE 'NO' END as Datacenter
- Advanced and likely more optimized approach:
Use Utrolig's answer: PIVOT should outperform due to less lookups (but always look at query plans when you optimize code!)
add a comment |
- Simple but not optimized approach: You need to LEFT OUTER JOIN table2 to table1 as many times as many AttrName's you would like to put in different columns in the final result. Each join should use a different alias name for table2 and filter on a specific AttrName:
FROM table1 as base
LEFT OUTER JOIN table2 as Datacenter on base.Id = Datacenter.Id and Datacenter.AttrName = 'Datacenter'
LEFT OUTER JOIN table2 as Cold on base.Id = Cold.Id and Cold.AttrName = 'Cold'
In the SELECT you need to check for the existence of matching lookup to the specific alias of table2 to define a column deriving from AttrName:
CASE WHEN Datacenter.Id IS NOT NULL THEN 'YES' ELSE 'NO' END as Datacenter
- Advanced and likely more optimized approach:
Use Utrolig's answer: PIVOT should outperform due to less lookups (but always look at query plans when you optimize code!)
- Simple but not optimized approach: You need to LEFT OUTER JOIN table2 to table1 as many times as many AttrName's you would like to put in different columns in the final result. Each join should use a different alias name for table2 and filter on a specific AttrName:
FROM table1 as base
LEFT OUTER JOIN table2 as Datacenter on base.Id = Datacenter.Id and Datacenter.AttrName = 'Datacenter'
LEFT OUTER JOIN table2 as Cold on base.Id = Cold.Id and Cold.AttrName = 'Cold'
In the SELECT you need to check for the existence of matching lookup to the specific alias of table2 to define a column deriving from AttrName:
CASE WHEN Datacenter.Id IS NOT NULL THEN 'YES' ELSE 'NO' END as Datacenter
- Advanced and likely more optimized approach:
Use Utrolig's answer: PIVOT should outperform due to less lookups (but always look at query plans when you optimize code!)
edited Nov 15 '18 at 9:25
answered Nov 15 '18 at 8:02
Dávid LaczkóDávid Laczkó
429128
429128
add a comment |
add a comment |
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.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53310200%2ft-sql-select-statement-multiple-column-with-case-statement-yes-or-no-based-on%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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
Please read this for some tips on improving your question. And why the
sp
tag?– HABO
Nov 14 '18 at 23:22
3
StackOverflow is not a code or SQL writing service. We expect you to make an effort to solve the problem yourself first. Once you've done so and run into difficulties, you can explain what you're trying to do and the problem you're having, include the relevant portions of your code, and ask a specific question related to that code, and we'll be glad to try to help. Your experiences here will be much better if you spend some time taking the tour and reading the help center pages, especially How to Ask, before you begin posting here.
– Ken White
Nov 14 '18 at 23:38
This is the query I have tried in isql and it worked. I'm working to accomplish in mssql. select a.id, a.Location,'Datacenter' =case when b1.AttrId=99 then 'yes' else 'No' end,'Cold'=case when b2.AttrId=88 then 'yes' else 'No' end from table1 a, (select Id,AttrId from table2 b where AttrId=99) b1, (select Id,AttrId from table2 b where AttrId=88) b2 where a.Id*=b1.Id and a.Id*=b2.Id
– MTC Entertainment
Nov 15 '18 at 12:27