Merging and consolidating rows by values based on date in SQL Server

3htmauhk  于 2023-03-22  发布在  SQL Server
关注(0)|答案(1)|浏览(147)

I have a table with driver number, date, state and time. I want to merge the rows with the same date and divide by driver number. and divide the time in the same line but according to the status Each status will get its own column The distribution of the status is according to numbers:

This is a table (Table name = Parking):
| DRIVER ID | date | status | TIME |
| ------------ | ------------ | ------------ | ------------ |
| 516 | 11/06/22 | 1 | 09:00 |
| 516 | 11/06/22 | 11 | 12:30 |
| 516 | 12/06/22 | 1 | 08:30 |
| 516 | 12/06/22 | 11 | 14:10 |
| 248 | 11/06/22 | 3 | 10:00 |
| 449 | 13/06/22 | 2 | 15:10 |
| 449 | 13/06/22 | 22 | 16:30 |
| 248 | 11/06/22 | 33 | 19:50 |
| 516 | 12/06/22 | 2 | 21:20 |
| 516 | 12/06/22 | 22 | 23:20 |

I need the division of the status in this way:

  • 1 - in1

  • 11 - Out1

  • 2 - in2

  • 22 - out2

  • 3 - in3

  • 33 - out3

Each driver will receive a table on his own, but only to export in CSV. All on the same CSV file. I don't need to input it in a new table or create a table

516-DriverA
| DRIVER ID | date | status-in1 | TIME | status-out1 | TIME | status-in2 | TIME | status-out2 | TIME | status-in3 | TIME | status-out3 | TIME | Total |
| ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ | ------------ |
| 516 | 11/06/22 | 1 | 09:00 | 11 | 12:30 | | | | | | | | | 03:30 |
| 516 | 12/06/22 | 1 | 08:30 | 11 | 14:10 | 2 | 21:20 | 22 | 23:20 | | | | | 07:40 |

248 DriverB

DRIVER IDdatestatus-in1TIMEstatus-out1TIMEstatus-in2TIMEstatus-out2TIMEstatus-in3TIMEstatus-out3TIMETotal
24812/06/22110:003319:5009:50

449 DriverB

DRIVER IDdatestatus-in1TIMEstatus-out1TIMEstatus-in2TIMEstatus-out2TIMEstatus-in3TIMEstatus-out3TIMETotal
44913/06/22215:102216:1001:00

I tried several ways, including a number of queries but I could not achieve this result

Hope this is doable, Thank you.

I checked some queries, tried to combine some options. But I couldn't get the result I want

41zrol4v

41zrol4v1#

You can use the SQL PIVOT function to pivot the "status" column and convert each status value into a separate column with its corresponding "time" value. You can also use the SQL aggregate function SUM to calculate the total time for each driver and date.

Here is an example query that should work for your table structure:

  1. SELECT
  2. [DRIVER ID],
  3. [date],
  4. [1] AS [status-in1],
  5. [out1] AS [status-out1],
  6. [2] AS [status-in2],
  7. [out2] AS [status-out2],
  8. [3] AS [status-in3],
  9. [out3] AS [status-out3],
  10. [total]
  11. FROM (
  12. SELECT
  13. [DRIVER ID],
  14. [date],
  15. 'in' + CAST([status] AS VARCHAR) AS [in_out],
  16. [time]
  17. FROM
  18. Parking
  19. WHERE
  20. [status] IN (1, 2, 3)
  21. UNION ALL
  22. SELECT
  23. [DRIVER ID],
  24. [date],
  25. 'out' + CAST([status] AS VARCHAR) AS [in_out],
  26. [time]
  27. FROM
  28. Parking
  29. WHERE
  30. [status] IN (11, 22, 33)
  31. ) AS SourceTable
  32. PIVOT (
  33. MAX([time])
  34. FOR [in_out] IN ([in1], [out1], [in2], [out2], [in3], [out3])
  35. ) AS PivotTable
  36. CROSS APPLY (
  37. SELECT
  38. ISNULL(SUM(DATEDIFF(MINUTE, [in1], [out1])), 0) +
  39. ISNULL(SUM(DATEDIFF(MINUTE, [in2], [out2])), 0) +
  40. ISNULL(SUM(DATEDIFF(MINUTE, [in3], [out3])), 0) AS [total]
  41. ) AS TotalTime
  42. WHERE
  43. [DRIVER ID] = '516'
  44. ORDER BY
  45. [date]

This query will pivot the "status" column and create separate columns for each status value with its corresponding "time" value. It will also calculate the total time for each driver and date using the SUM and DATEDIFF functions to calculate the difference between the in and out time in minutes.

Note: You can change the driver ID in the WHERE clause to get the results for a different driver. Also, you can modify the column names and formatting to match your desired output. Finally, you can export the results to a CSV file using your database management tool or a programming language.

展开查看全部

相关问题