编者:李国帅
qq:9611153 微信lgs9611153
时间:2008-7-22
背景:
我们在操作数据的时候,会用到把一个较大数据存入数据库,字段类型可以使用blob,如果不是太大,也可以使用[varchar] (5000)字段存入较长数据。
下面在sqlserver中对插入大数据并查询进行了测试,分析了其中遇到的问题。
问题描述:
插入二进制这种操作,在查询管理器中编写和执行,有问题也不直观,因为很多字符根本无法显示。所以一般是在程序中使用代码方式直接存入的。
同时如果打印的话,可以使用convert(varbinary(的方式打印,虽然只能显示128个字符,但是二进制大数据确实已经存入数据库。
所需资源:
Sqlserver2000,查询分析器
插入数据:
编写插入数据,然后在ultraEdit中查看。
打印发现数据长度不对,print只能显示Message小于128的部分
--SET ANSI_PADDING ON
--print convert(varbinary(4096),'??0\t99999999999999541212-541216-54121232111114-541212321111133119.18.32!22;41.14121111111')
--反向查看
INSERT INTO [mydb].[dbo].[UnSendCommInfo]( [Type], [SendStatus], [Message])
VALUES( 303, 0, 0x3F3F010130020101055C7401013939393939393939393939393939050101013534313231322D3534313231362D35343132313233323131313131342D3534313231323332313131313133010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101333131392E31382E33322132323B34312E31340131323131313131313101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101)
实际数据是多少呢?
--insert into unsendcomminfo values(303,0,convert(varbinary(4096),'??0\t99999999999999541212-541216-54121232111114-541212321111133119.18.32!22;41.14121111111'))
--反向查看
--print len(convert(varchar(4096),0x3F3F010130020101055C7401013939393939393939393939393939050101013534313231322D3534313231362D35343132313233323131313131342D3534313231323332313131313133010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101))
select len(message) from UnSendCommInfo --4071
select convert(varchar(4096),message) from unsendcomminfo
--select * from UnSendCommInfo
--print len('...')
delete from unsendcomminfo
--SET ANSI_PADDING OFF
虽然只能打印出128个字节,实际上已经存入数据库
总结:
数据库中保留大数据字段也是有用处的,虽然日常生工作中更喜欢把文件直接存储在磁盘中,在数据库中仅仅保存文件地址。
我认为,如果是单文件数据,比如txt,word之类的不妨直接存到数据库;如果是html这样的文件,因为可能关联文件的数据,不妨直接使用文件方式存放。