你用数据库管理器选中数据库,先分离,然后再附加,然后再点收缩,收缩的时候先收缩日志文件,一般能收缩很多,记得要填写数字啊,比如上面提示能收缩为0,你就填个5兆,这样预留一点空间,而且很快,收缩完日志文件之后再收缩数据库 同理比最小能收缩量大几兆就可以了,但是收缩数据库比较慢 需要很多时间
提升数据库性能可以提升查询速度,优化数据库结构,减少服务器压力等,那么如何优化数据库呢?昌平电脑培训来看看下面的文章!
1数据库I/O方面硬件性能
最有可能影响性能的是磁盘和网络吞吐量。解决办法:
·扩大虚拟内存,并保证有足够可以扩充的空间
·把数据库服务器上的不必要服务关闭掉
·把SQL数据库服务器的吞吐量调为最大
2调整数据库
·若对该表的查询频率比较高,则建立索引。
·分区(如MySQL,按时间分区)
·尽量使用固定长度字段和限制字段长度(如varchar(10))优势:
降低物理存储空间
提高数据库处理速度
附带校验数据库是否合法功能
3使用存储过程
应用程序的实现过程中,能够采用存储过程实现的对数据库的 *** 作尽量通过存储过程来实现。
因为存储过程是存放在数据库服务器上的一次性被设计、编码、测试,并被再次使用,需要执行该任务的应用可以简单地执行存储过程,并且只返回结果集或者数值。
这样不仅可以使程序模块化,同时提高响应速度,减少网络流量,并且通过输入参数接受输入,使得在应用中完成逻辑的一致性实现。
4SQL语句方面
建立查询条件索引仅仅是提高速度的前提条件,响应速度的提高还依赖于对索引的使用。不良的SQL往往来自于不恰当的索引设计、不充份的连接条件和不可优化的where子句。
·优化sql语句,减少比较次数
·限制返回条目数(mysql中使用limit)
首先看看此数据库下是否还有其他表有大量数据,如果没有是否由于以前存在大量数据,在删除之后,没有清除日志呢,收缩下日志,再把数据库备份一下,看看备份文件是否明显变小。
清除数据库语句:
backup log 数据库名 with no_log
dbcc shrinkdatabase (数据库名)
替换‘数据库名’为你的数据库名称,并执行,执行结束后再备份即可。
这个说法是正确的。原因如下:
数据库系统的特点有四个:
1,数据结构化。采用数据模型来对数据进行描述和定义。
2,数据共享性高,冗余度低。由于是从全局分析和描述数据,就可以适合多个用户、各种应用共享数据的需求。信息可在统一的地方存储,共享的同时可显著减少数据冗余,节省存储空间。但是,并不是说完全没有冗余,只是相对冗余度降低而已。
3,数据独立于程序。包括逻辑和物理独立性。
4,统一管理和控制数据。由于数据库系统是数据密集型应用,一次统一管理和控制尤其重要。
所以,数据库系统减少了数据的冗余这一说法是正确的。
希望能帮到您。谢谢。
这是因为删除 *** 作后在数据文件中留下碎片所致。DELETE只是将数据标识位删除,并没有整理数据文件,当插入新数据后,会再次使用这些被置为删除标识的记录空间。另外实际 *** 作过程中还发现这个问题还存在两种情况。
(1)当DELETE后面跟条件的时候,则就会出现这个问题。如:
deletefromtable_namewhere条件
删除数据后,数据表占用的空间大小不会变。
(2)不跟条件直接delete的时候。如:
deletefromtable_name
清除了数据,同时数据表的空间也会变为0。
这就存在了一个问题,在网站的实际运行过程中。经常会存在这样的附带条件删除数据的 *** 作行为。天长日久,这不就在数据库中浪费了很多的空间吗。这个时候我们该使用OPTIMIZETABLE指令对表进行优化了。
如何使用OPTIMIZE以及在什么时候该使用OPTIMIZE指令呢?
命令语法:OPTIMIZE[LOCAL|NO_WRITE_TO_BINLOG]TABLEtbl_name[,tbl_name]
最简单的:optimizetablephpernote_article;
如果您已经删除了表的一大部分,或者如果您已经对含有可变长度行的表(含有VARCHAR,BLOB或TEXT列的表)进行了很多更改,则应使用
OPTIMIZETABLE。被删除的记录被保持在链接清单中,后续的INSERT *** 作会重新使用旧的记录位置。您可以使用OPTIMIZE
TABLE来重新利用未使用的空间,并整理数据文件的碎片。
在多数的设置中,您根本不需要运行OPTIMIZETABLE。即使您对可变长度的行进行了大量的更新,您也不需要经常运行,每周一次或每月一次即可,只对特定的表运行。
OPTIMIZETABLE只对MyISAM,BDB和InnoDB表起作用。
注意,在OPTIMIZETABLE运行过程中,MySQL会锁定表。因此,这个 *** 作一定要在网站访问量较少的时间段进行。
TRUNCATE
其语法结构为:
TRUNCATE[TABLE]tbl_name
这里简单的给出个示例,
我想删除friends表中所有的记录,可以使用如下语句:
truncatetablefriends;
delete的效果有点像将mysql表中所有记录一条一条删除到删完,而truncate相当于保留mysql表的结构,重新创建了这个表,所有的状态都相当于新表,这样空间就减下来了。
好了,当然对于我们网站不可能使用truncatetable来清除了,因这样之后所有数据都丢失了,这样肯定是不合理的清除了,我们必须使用delete来删除,然后再来修复优化表了哦。
以上就是关于如何收缩sqlserver数据库全部的内容,包括:如何收缩sqlserver数据库、昌平电脑培训分享提高数据库的性能、sql server 2005 有一个表有只有2W 多条数据,但是数据空间却有4.5G请问,有什么办法处理呢等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)