如何在SQL Server Management Studio中查看NTEXT或NVARCHAR(max)中的所有文本?默认情况下,它似乎只返回前几百个字符(255?),但有时我只是想要一种快速查看整个字段的方法,而不必编写程序来做到这一点。即使是SSMS 2012仍然存在这个问题:(
当前回答
快速技巧-
SELECT CAST('<A><![CDATA[' + CAST(LogInfo as nvarchar(max)) + ']]></A>' AS xml)
FROM Logs
WHERE IDLog = 904862629
其他回答
今天我用这个方法成功了。它与其他答案相似,它也将内容转换为XML,只是使用了不同的方法。由于我没有在答案中看到FOR XML PATH,我想为了完整性,我应该添加它:
SELECT [COL_NVARCHAR_MAX]
FROM [SOME_TABLE]
FOR XML PATH(''), ROOT('ROOT')
这将交付一个包含所有行内容的有效XML,嵌套在一个外部<ROOT></ROOT>元素中。每一行的内容都包含在一个元素中,在本例中,该元素称为<COL_NVARCHAR_MAX>。它的名称可以通过AS使用别名来更改。
特殊字符如&、<或>或类似字符将被转换为它们各自的实体。所以你可能需要转换<, >和,回到它们原来的字符,这取决于你需要对结果做什么。
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')
替代方案1:右键单击复制单元格并粘贴到文本编辑器(希望与utf-8支持)
方法2:右键单击,导出到CSV文件
替代方案3:使用SUBSTRING函数来可视化列的各个部分。例子:
SELECT SUBSTRING(fileXml,2200,200) FROM mytable WHERE id=123456
在较新版本的SSMS中,可以在(查询/查询选项/结果/网格/最大字符检索)菜单中配置:
旧版本的SSMS
选项(查询结果/SQL Server/网格页面结果)
如果要更改当前查询的选项,请在“查询”菜单中单击“查询选项”,或在“SQL Server查询”窗口中单击右键,选择“查询选项”。
...
最大字符检索 输入一个从1到65535的数字来指定在每个单元格中显示的最大字符数。
如你所见,最大值是64k。默认值要小得多。
BTW,结果到文本有更激烈的限制:
每列显示的最大字符数 该值默认为256。增加此值以显示更大的结果集而不截断。最大值为8192。
快速查看大型varchar/text列的最简单方法:
declare @t varchar(max)
select @t = long_column from table
print @t
以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参数设置为适合您需要的值。
推荐文章
- 如何在SSMS中从ntext或nvarchar(max)查看所有文本?
- 创建表如果在SQL Server中不存在
- MSSQL错误“底层提供者在打开时失败”
- 如何通过使用T-SQL划分两个整数值来获得一个浮点结果?
- 如何为包含所有存储行的现有SQL Server表生成INSERT脚本?
- 如何获取SQL Server数据脚本?
- 在SQL Server中查找重复的行
- 执行带有Output参数的存储过程?
- 从DateTime中提取小时(SQL Server 2005)
- 我如何在T-SQL用逗号格式化一个数字?
- LEFT OUTER JOIN如何返回比左表中存在的记录更多的记录?
- 如何用SQL语句计算百分比
- SQL Server动态PIVOT查询?
- 如何等待2秒?
- SQL Server: CROSS JOIN和FULL OUTER JOIN的区别是什么?