I have table with columns Monday
, Tuesday
, Wednesday
, Thursday
and Friday
and are of Boolean type now I want to make a query to convert these rows to single column Weekday
. It Should show me name of day of which column is true.
How to repeat rows based on different columns in SQL Server
133 views Asked by Adil Farhan Farhan At
3
There are 3 answers
0
data:image/s3,"s3://crabby-images/66c17/66c178474f0b0e167705b9d76786bac4f5950af5" alt="Tim Biegeleisen"
As pointed out, SQL Server does not have a boolean type, but it does have a BIT
type which can only take on two values, 0 and 1. I am assuming that you are using a bit column. I also assume that only one day will be selected in each row. With both of these assumptions, you just need a single CASE
expression:
SELECT
CASE WHEN Monday = 1 THEN 'Monday'
WHEN Tuesday = 1 THEN 'Tuesday'
WHEN Wednesday = 1 THEN 'Wednesday'
WHEN Thursday = 1 THEN 'Thursday'
WHEN Friday = 1 THEN 'Friday' END AS day_selected
FROM yourTable
2
data:image/s3,"s3://crabby-images/66c17/66c178474f0b0e167705b9d76786bac4f5950af5" alt="shA.t"
Note: I think you mean
bit
type instead ofBoolean
that accepts only0
/1
.
A mathematical way can be this:
select
datename(weekday,
Monday + Tuesday*2 + Wednesday*3 + Thursday*4 + Friday*5 - 1) as weekDayName
from
t;
Side Note:
datename(weekday, 0) => Monday datename(weekday, 1) => Tuesday datename(weekday, 2) => Wednesday datename(weekday, 3) => Thursday datename(weekday, 4) => Friday datename(weekday, 5) => Saturday datename(weekday, 6) => Sunday / datename(weekday, -1) => Sunday
You can use
case
. To get a comma-delimited list in SQL Server:I don't know how you specify "true" values. The above assumes that non-zero values are true.