Home Database Mysql Tutorial sqlserver 将多行数据查询合并为一条数据

sqlserver 将多行数据查询合并为一条数据

Jun 07, 2016 pm 03:34 PM
sqlserver Multi-line data data query

有这样一个需求:表T_FUN_TASK为任务表,有字段(TASKID,TASKNAME),表T_FUN_LOGBOOK为日志表,有字段(LOGID,TASKID,LOGDATE),一个任务可持续多天,每天会记录一条日志。在查询表T_FUN_TASK时,需将任务表中的 LOGDATE 查询出来作为一列 LOGDATES显示。

有这样一个需求:表T_FUN_TASK为任务表,有字段(TASKID,TASKNAME),表T_FUN_LOGBOOK为日志表,有字段(LOGID,TASKID,LOGDATE),一个任务可持续多天,每天会记录一条日志。在查询表T_FUN_TASK时,需将任务表中的 LOGDATE 查询出来作为一列 LOGDATES显示。

sqlserver 将多行数据查询合并为一条数据   

T_FUN_TASK

sqlserver 将多行数据查询合并为一条数据

T_FUN_LOGBOOK  

sqlserver 将多行数据查询合并为一条数据

查询结果

此结果查询方法可以用存储过程轻松实现,这里我要介绍的是sqlserver FOR XML PATH语句的应用,在SQL Server中利用 FOR XML PATH 语句能够把查询的数据生成XML数据

且合并为一条数据,看以下示例:

<span>SELECT</span> LOGDATE <span>FROM</span> T_FUN_LOGBOOK <span>WHERE</span> TASKID<span>=</span><span>231</span> <span>FOR</span> XML PATH
Copy after login

结果为:


2014-01-06T00:00:00


2014-01-07T00:00:00

首先,将日期格式转化为需要的格式:

<span>SELECT</span> <span>CONVERT</span>(<span>VARCHAR</span>(<span>100</span>), LOGDATE, <span>111</span>) <span>FROM</span> T_FUN_LOGBOOK <span>WHERE</span> TASKID<span>=</span><span>231</span> <span>FOR</span> XML PATH
Copy after login

结果变为:

2014/01/06
2014/01/07

<span>SELECT</span> <span>CONVERT</span>(<span>VARCHAR</span>(<span>100</span>), LOGDATE, <span>111</span>) <span>FROM</span> T_FUN_LOGBOOK <span>WHERE</span> TASKID<span>=</span><span>231</span> <span>FOR</span> XML PATH('')
Copy after login

现在两条结果之间很难区分,需要用下划线将其分隔开来,方法是在CONVERT函数前面加上一个下划线:

<span>SELECT</span> <span>'</span><span>_</span><span>'</span><span>+</span><span>CONVERT</span>(<span>VARCHAR</span>(<span>100</span>), LOGDATE, <span>111</span>) <span>FROM</span> T_FUN_LOGBOOK <span>WHERE</span> TASKID<span>=</span><span>231</span> <span>FOR</span> XML PATH(<span>''</span>)
Copy after login

结果:_2014/01/06_2014/01/07。

在分析了FOR XML PATH语句之后,就来将这个查询结果添加到对T_FUN_TASk的查询结果中去。我的思路是先构建一个子查询,然后查询TASK表时LEFT JOIN这个子查询

<span>SELECT</span> T1.TASKID,<span>'</span><span>TASKNAME</span><span>'</span> <span>AS</span> TASKNAME,T2.LOGDATES <span>FROM</span><span> T_FUN_TASK T1

</span><span>LEFT</span> <span>JOIN</span> (<span>SELECT</span><span> TASKID, 
LOGDATES</span><span>=</span>(<span>SELECT</span> <span>'</span><span>_</span><span>'</span><span>+</span><span>CONVERT</span>(<span>VARCHAR</span>(<span>100</span>), LOGDATE, <span>111</span>) <span>FROM</span> T_FUN_LOGBOOK <span>WHERE</span> TASKID<span>=</span>T1.TASKID <span>FOR</span> XML PATH(<span>''</span>)) <span>FROM</span><span> T_FUN_LOGBOOK T1 
</span><span>GROUP</span> <span>BY</span> TASKID) T2 <span>ON</span> T2.TASKID<span>=</span><span>T1.TASKID

</span><span>ORDER</span> <span>BY</span> T1.TASKID <span>ASC</span>
Copy after login

运行以上SQL后得到的结果为:

sqlserver 将多行数据查询合并为一条数据

发现LOGDATES值的第一个下划线应该去掉,于是修改SQL,应用 STUFF函数去掉第一个下划线:

<span>SELECT</span> T1.TASKID,<span>'</span><span>TASKNAME</span><span>'</span> <span>AS</span> TASKNAME,T2.LOGDATES <span>FROM</span><span> T_FUN_TASK T1

</span><span>LEFT</span> <span>JOIN</span> (<span>SELECT</span><span> TASKID, 
LOGDATES</span><span>=</span><span>STUFF</span>((<span>SELECT</span> <span>'</span><span>_</span><span>'</span><span>+</span><span>CONVERT</span>(<span>VARCHAR</span>(<span>100</span>), LOGDATE, <span>111</span>) <span>FROM</span> T_FUN_LOGBOOK <span>WHERE</span> TASKID<span>=</span>T1.TASKID <span>FOR</span> XML PATH(<span>''</span>)),<span>1</span>,<span>1</span>,<span>''</span>) <span>FROM</span><span> T_FUN_LOGBOOK T1 
</span><span>GROUP</span> <span>BY</span><span> TASKID) T2
</span><span>ON</span> T2.TASKID<span>=</span><span>T1.TASKID

</span><span>ORDER</span> <span>BY</span> T1.TASKID <span>ASC</span>
Copy after login

将结果转化为JSON 返回给前端之后,JS按照下划线分隔这个字段的值,即可以得到一个任务下面日志的填写情况。

 

 

 

 

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to solve the problem that the object named already exists in the sqlserver database How to solve the problem that the object named already exists in the sqlserver database Apr 05, 2024 pm 09:42 PM

For objects with the same name that already exist in the SQL Server database, the following steps need to be taken: Confirm the object type (table, view, stored procedure). IF NOT EXISTS can be used to skip creation if the object is empty. If the object has data, use a different name or modify the structure. Use DROP to delete existing objects (use caution, backup recommended). Check for schema changes to make sure there are no references to deleted or renamed objects.

How to import mdf file into sqlserver How to import mdf file into sqlserver Apr 08, 2024 am 11:41 AM

The import steps are as follows: Copy the MDF file to SQL Server's data directory (usually C:\Program Files\Microsoft SQL Server\MSSQL\DATA). In SQL Server Management Studio (SSMS), open the database and select Attach. Click the Add button and select the MDF file. Confirm the database name and click the OK button.

What to do if the sqlserver service cannot be started What to do if the sqlserver service cannot be started Apr 05, 2024 pm 10:00 PM

When the SQL Server service fails to start, here are some steps to resolve: Check the error log to determine the root cause. Make sure the service account has permission to start the service. Check whether dependency services are running. Disable antivirus software. Repair SQL Server installation. If the repair does not work, reinstall SQL Server.

How to check sqlserver port number How to check sqlserver port number Apr 05, 2024 pm 09:57 PM

To view the SQL Server port number: Open SSMS and connect to the server. Find the server name in Object Explorer, right-click it and select Properties. In the Connection tab, view the TCP Port field.

Where is the sqlserver database? Where is the sqlserver database? Apr 05, 2024 pm 08:21 PM

SQL Server database files are usually stored in the following default location: Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data The database file location can be customized by modifying the database file path setting.

How to recover accidentally deleted database in sqlserver How to recover accidentally deleted database in sqlserver Apr 05, 2024 pm 10:39 PM

If you accidentally delete a SQL Server database, you can take the following steps to recover: stop database activity; back up log files; check database logs; recovery options: restore from backup; restore from transaction log; use DBCC CHECKDB; use third-party tools. Please back up your database regularly and enable transaction logging to prevent data loss.

How to delete sqlserver if the installation fails? How to delete sqlserver if the installation fails? Apr 05, 2024 pm 11:27 PM

If the SQL Server installation fails, you can clean it up by following these steps: Uninstall SQL Server Delete registry keys Delete files and folders Restart the computer

The vitality of super intelligence awakens! But with the arrival of self-updating AI, mothers no longer have to worry about data bottlenecks The vitality of super intelligence awakens! But with the arrival of self-updating AI, mothers no longer have to worry about data bottlenecks Apr 29, 2024 pm 06:55 PM

I cry to death. The world is madly building big models. The data on the Internet is not enough. It is not enough at all. The training model looks like "The Hunger Games", and AI researchers around the world are worrying about how to feed these data voracious eaters. This problem is particularly prominent in multi-modal tasks. At a time when nothing could be done, a start-up team from the Department of Renmin University of China used its own new model to become the first in China to make "model-generated data feed itself" a reality. Moreover, it is a two-pronged approach on the understanding side and the generation side. Both sides can generate high-quality, multi-modal new data and provide data feedback to the model itself. What is a model? Awaker 1.0, a large multi-modal model that just appeared on the Zhongguancun Forum. Who is the team? Sophon engine. Founded by Gao Yizhao, a doctoral student at Renmin University’s Hillhouse School of Artificial Intelligence.

See all articles