怎样压缩sql server2000的数据库备份文件,像rar一样?小弟有一7m的sql server2000
数据库备份文件,在程序中怎样压缩啊?
procedure TForm1.Button2Click(Sender: TObject); var SHExecInfo: SHELLEXECUTEINFO; begin SHExecInfo.cbSize := sizeof(SHELLEXECUTEINFO); SHExecInfo.fMask := SEE_MASK_NOCLOSEPROCESS; SHExecInfo.Wnd := Handle; SHExecInfo.lpVerb := nil; SHExecInfo.lpFile := 'WinRAR.exe'; SHExecInfo.lpParameters := 'a e:qwqw.rar e:qwqw'; SHExecInfo.lpDirectory := nil; SHExecInfo.nShow := SW_SHOW; SHExecInfo.hInstApp := Handle; ShellExecuteEx(@SHExecInfo); WaitForSingleObject(SHExecInfo.hProcess, INFINITE); CloseHandle(SHExecInfo.hProcess); ShellExecute(application.MainForm.Handle,'open','winrar.exe',PChar('a e:zqzq.rar e:zqzq'),'',SW_show); ShowMessage('压缩完毕!'); }
这是一段压缩图片的代码,压缩文件原理相同,只需稍做改动即可。
var mss: TMemoryStream; zip: TDeCompressionStream; zip1: TCompressionStream; fs : TFileStream; fBuf: Array[0..16383] of Byte; flen: Integer; //从数据库中取出图片 //...写出SQL语句以取得有图片的记录,此处从略 mss := TMemoryStream.Create; fs := TFileStream.Create('filename.jpg',fmCreate or fmOpenWrite); try TBlobField(Que.FieldByName('pic')).SaveToStream(mss); zip := TDeCompressionStream.Create(fs); try flen := zip.Read(fbuf, SizeOf(fBuf)); while flen > 0 do begin fs.Write(fbuf, flen); flen := zip.Read(fbuf, SizeOf(fBuf)); end; finally FreeAndNil(zip); end; finally mss.Free; fs.Free; end; //将文件filename.jpg中的图片保存到数据库 //...写出SQL语句,打开Que,并定位到要保存图片的记录,此处从略 fs := TFileStream.Create('filename.jpg',fmOpenRead); mss := TMemoryStream.Create; try zip1 := TCompressionStream.Create(clDefault,mss); try flen := fs.Read(fbuf, SizeOf(fBuf)); while flen > 0 do begin zip1.Write(fbuf, flen); flen := fs.Read(fbuf, SizeOf(fBuf)); end; //保存到数据库 TBlobField(Que.FieldByName('pic')).LoadFromStream(mss); Que.UpdateBatch(); //... finally zip1.Free; end; finally fs.Free; mss.Free; end;
© 版权声明
本文刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等部门来源于互联网,版权均归原作者所有!本网站提供的内容服务于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
联系信息:邮箱aoxolcom@163.com或见网站底部。
联系信息:邮箱aoxolcom@163.com或见网站底部。
THE END
请登录后发表评论
注册
社交帐号登录