sql2005数据库中存储的image类型数据比原图像大好几倍

dyiajure 2010-09-06 05:29:32
最近发现数据库硬盘空间不够了,一查原来是存的图像数据过大,要比原图像数据大3倍左右,我是把图像转成jpg或者tif后存到数据库中的,image类型,网上查了下image类型是按二进制存的,为什么会大好几倍呢?是因为jpg格式是可压缩的么?如何才能给图像数据“瘦身”?

另想问下有没有脚本能把现有图像数据压缩后再存到原来的表中,能提供脚本最好,关键字也行
...全文
105 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
dyiajure 2010-09-07
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 sqlcenter 的回复:]

SQL code
-- 测试一个jpg文件,大小为147191字节

create table # (img image, bin varbinary(max))

insert #(img) select * from OPENROWSET(BULK N'X:\...\xxx.jpg', SINGLE_BLOB) as t
update # set bin = BulkColumn from……
[/Quote]

谢谢你的帮助,我再查下数据库
dyiajure 2010-09-07
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 ws_hgo 的回复:]

SQL code
你的意思你以前的图片格式使用image类型
现在想转换为字符串类型如图片的名称:1.jpg或者是.gif
[/Quote]

是原始图片格式是jpg或者tif的,在存储到数据库中数据量增大了,我理解都是二进制数据顶多增加一些索引开销,怎么会是原来的几倍呢?
SQLCenter 2010-09-06
  • 打赏
  • 举报
回复
-- 测试一个jpg文件,大小为147191字节

create table # (img image, bin varbinary(max))

insert #(img) select * from OPENROWSET(BULK N'X:\...\xxx.jpg', SINGLE_BLOB) as t
update # set bin = BulkColumn from OPENROWSET(BULK N'X:\...\xxx.jpg', SINGLE_BLOB) as t

select imgLen=datalength(img), img, binLen=datalength(bin), bin from #

/*
imgLen img binLen bin
----------- --------------- -------------------- ---------------
147191 0xFFD8FFE000... 147191 0xFFD8FFE000...
*/

-- 测试结果:用image或varbinary(max)类型存储都不会导致空间膨胀,大不了就是每张图片多16字节的指针

drop table #
「已注销」 2010-09-06
  • 打赏
  • 举报
回复
图片、声音文件,建议通过guid保存文件名到表中,具体文件copy到服务器下,这样对应起来就可以了。
obuntu 2010-09-06
  • 打赏
  • 举报
回复
没研究过,但对于图像,一般建议是存图像地址,图片则放在硬盘上。
ws_hgo 2010-09-06
  • 打赏
  • 举报
回复
你的意思你以前的图片格式使用image类型
现在想转换为字符串类型如图片的名称:1.jpg或者是.gif
dyiajure 2010-09-06
  • 打赏
  • 举报
回复
看来晚上没什么人啊,等明天了##!
wangguojunmy 2010-09-06
  • 打赏
  • 举报
回复
路过,关注学习啊!

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧