如何在SQL Server Management Studio中查看NTEXT或NVARCHAR(max)中的所有文本?默认情况下,它似乎只返回前几百个字符(255?),但有时我只是想要一种快速查看整个字段的方法,而不必编写程序来做到这一点。即使是SSMS 2012仍然存在这个问题:(


当前回答

如果你只需要查看它,我使用了这个:

print cast(dbo.f_functiondeliveringbigformattedtext(seed) as text)

最终的结果是,我得到换行和所有的内容在短信窗口的消息。 当然,它只允许一个单元格-如果你想从一些行中做一个单元格,你可以这样做:

declare @T varchar(max)=''
select @T=@T
       + isnull(dbo.f_functiondeliveringbigformattedtext(x.a),'NOTHINGFOUND!')
       + replicate(char(13),4)
from x -- table containing multiple rows and a value in column a
print @T

我使用它来验证SQL代码生成的JSON字符串。否则太难读了!

其他回答

以XML格式返回数据

SELECT CONVERT(XML, [Data]) AS [Value]
FROM [dbo].[FormData]
WHERE [UID] LIKE '{my-uid}'

确保您在SSMS选项窗口中设置了合理的限制,具体取决于您期望的结果。

如果你返回的文本不包含未编码的字符,比如&而不是&这将导致XML转换失败。

使用PowerShell返回数据

为此,您需要在将要运行命令的机器上安装PowerShell SQL Server模块。

如果你已经设置好了,配置并运行下面的脚本:

Invoke-Sqlcmd -Query "SELECT [Data] FROM [dbo].[FormData] WHERE [UID] LIKE '{my-uid}'" -ServerInstance "database-server-name" -Database "database-name" -Username "user" -Password "password" -MaxCharLength 10000000 | Out-File -filePath "C:\db_data.txt"

确保您将-MaxCharLength参数设置为适合您需要的值。

如果你只需要查看它,我使用了这个:

print cast(dbo.f_functiondeliveringbigformattedtext(seed) as text)

最终的结果是,我得到换行和所有的内容在短信窗口的消息。 当然,它只允许一个单元格-如果你想从一些行中做一个单元格,你可以这样做:

declare @T varchar(max)=''
select @T=@T
       + isnull(dbo.f_functiondeliveringbigformattedtext(x.a),'NOTHINGFOUND!')
       + replicate(char(13),4)
from x -- table containing multiple rows and a value in column a
print @T

我使用它来验证SQL代码生成的JSON字符串。否则太难读了!

快速查看大型varchar/text列的最简单方法:

declare @t varchar(max)

select @t = long_column from table

print @t

今天我用这个方法成功了。它与其他答案相似,它也将内容转换为XML,只是使用了不同的方法。由于我没有在答案中看到FOR XML PATH,我想为了完整性,我应该添加它:

SELECT [COL_NVARCHAR_MAX]
  FROM [SOME_TABLE]
  FOR XML PATH(''), ROOT('ROOT')

这将交付一个包含所有行内容的有效XML,嵌套在一个外部<ROOT></ROOT>元素中。每一行的内容都包含在一个元素中,在本例中,该元素称为<COL_NVARCHAR_MAX>。它的名称可以通过AS使用别名来更改。

特殊字符如&、<或>或类似字符将被转换为它们各自的实体。所以你可能需要转换&lt;, &gt;和,回到它们原来的字符,这取决于你需要对结果做什么。

EDIT

我刚刚意识到CDATA也可以使用FOR XML指定。不过我觉得有点麻烦。这样可以做到:

SELECT 1 as tag, 0 as parent, [COL_NVARCHAR_MAX] as [COL_NVARCHAR_MAX!1!!CDATA]
  FROM [SOME_TABLE]
  FOR XML EXPLICIT, ROOT('ROOT')

快速技巧-

SELECT CAST('<A><![CDATA[' + CAST(LogInfo as nvarchar(max)) + ']]></A>' AS xml)
FROM Logs
WHERE IDLog = 904862629