直接压缩不太现实啊,文件太大需要的时间太长了。
如果里面的数据资料不重要,只是数据结构重要的话,可以再导出一个只含数据结构的数据库副本。
或者 如果日志文件不重要的话,可以只导出数据库本身,不导出日志。
最后,7G文件也不算大,我这里就是用一个160G的移动硬盘备份的,不过一定要把硬盘格式化成NTFS格式。
1备份MySQL数据库的命令
mysqldump-hhostname-uusername-ppassworddatabasename>backupfilesql
2备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
mysqldump-_add-drop-table-uusername-ppassworddatabasename>backupfilesql
3直接将MySQL数据库压缩备份
mysqldump-hhostname-uusername-ppassworddatabasename|gzip>backupfilesqlgz
4备份MySQL数据库某个(些)表
mysqldump-hhostname-uusername-ppassworddatabasenamespecific_table1specific_table2>backupfilesql
5同时备份多个MySQL数据库
mysqldump-hhostname-uusername-ppassword_databasesdatabasename1databasename2databasename3>multibackupfilesql
6仅仅备份数据库结构
mysqldump_no-data_databasesdatabasename1databasename2databasename3>structurebackupfilesql
7备份服务器上所有数据库
mysqldump_all-databases>allbackupfilesql
8还原MySQL数据库的命令
mysql-hhostname-uusername-ppassworddatabasename<backupfilesql
9还原压缩的MySQL数据库
gunzip<backupfilesqlgz|mysql-uusername-ppassworddatabasename
10将数据库转移到新服务器
mysqldump-uusername-ppassworddatabasename|mysql_host=-Cdatabasename
具体方法有3种。
方法一:
第一步:
backup
log
database_name
with
no_log
或者
backup
log
database_name
with
truncate_only
--
no_log和truncate_only是在这里是同义的,随便执行哪一句都可以。
第二步:
1收缩特定数据库的所有数据和日志文件,执行:
dbcc
shrinkdatabase
(database_name,[,target_percent])
--
database_name是要收缩的数据库名称;target_percent是数据库收缩后的数据库文件中所要的剩余可用空间百分比。
2收缩一次一个特定数据库中的数据或日志文件,执行
dbcc
shrinkfile(file_id,[,target_size])
--
file_id是要收缩的文件的标识
(id)
号,若要获得文件
id,请使用
file_id
函数或在当前数据库中搜索
sysfiles;target_size是用兆字节表示的所要的文件大小(用整数表示)。如果没有指定,dbcc
shrinkfile
将文件大小减少到默认文件大小。两个dbcc都可以带上参数notruncate或truncateonly,具体意思查看联机帮助
方法二:
第一步:
先备份整个数据库以备不测
。
第二步:
备份结束后,在query
analyzer中执行如下的语句:
exec
sp_detach_db
yourdbname,true
--卸除这个db在mssql中的注册信息
第三步:
到日志的物理文件所在的目录中去删除该日志文件或者将该日志文件移出该目录
第四步:
在query
analyzer中执行如下的语句:
exec
sp_attach_single_file_db
yourdbname,'
d:\mssql\data\yourdbname_datamdf
'
--以单文件的方式注册该db,如果成功则mssql将自动为这个db生成一个500k的日志文件。
方法三:
1
进入企业管理器,选中数据库,比如demo
2
所有任务->分离数据库
3
到数据库文件的存放目录,将muonline_logldf文件删除,以防万一,你可以拷出去
4
企业管理器->附加数据库,选muonline,这个时候你会看见日志文件这项是一个叉,不要紧,继续,此时数据库就会提示你该数据库无日志是否创建一个新的,确定就是了。
5
记得数据库重新附加后用户要重新设置一下。
如果以后,不想要它变大:
sql2000下使用:
在数据库上点右键->属性->选项->故障恢复-模型-选择-简单模型。
或用sql语句:
alter
database
数据库名
set
recovery
simple
以上就是关于SqlServer数据库备份文件.bak如何压缩全部的内容,包括:SqlServer数据库备份文件.bak如何压缩、MySQL数据库备份和还原的常用命令、SQL数据库如何压缩等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)