Table '/v3dvcom/common_credit_rule_log' is marked as crashed and should be repaired
提示了错误的位置,数据库中的表被标识为破坏,应该修复。
1、例如,mysql数据库的表内容太大,超过10G可能会影响discuz论坛的运行。
2、这种情况可以通过子数据库的方法来解决。有关详细信息,您可以搜索discuz官方网站以查找相关信息。
3、数据库配置错误,有时可能是主机移动,数据库移动等,导致数据库信息填写不正确,或者旧数据库信息未及时更新,例如数据库用户名,密码,数据库表填充错误。
4、您可以修复相关的数据库信息,您可以在config目录中找到config目录,修改数据库信息配置文件。 Discus!3有三个参考配置文件。仔细检查数据库配置和其他配置是否是最新的。
安装目录/config/config_globalphp安装目录/config/config_ucenterphp安装目录/uc_server/data/configincphp。有关详细信息,请参阅discuz官方文档。
5、数据库没有运行。
6、检查主机的mysql数据库程序是否正在运行或已关闭。如果它是虚拟主机,您可以联系空间提供商以将其打开。如果虚拟主机不支持mysql数据库,则可以通过替换主机或空间提供程序来解决此问题。
方法1:
第一步:
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,具体意思看帮助。
方法2
(这个方法在sqlserver2000的环境下做一般能成功,在sqlserver7及以下版本就不一定了):
第一步:
先备份整个数据库以备不测
第二步:
备份结束后,在Query Analyzer中执行如下的语句:
exec sp_detach_db yourDBName,true --卸除这个DB在MSSQL中的注册信息
第三步:
到日志的物理文件所在的目录中去删除该日志文件或者将该日志文件移出该目录
第四步:
在Query Analyzer中执行如下的语句:
exec sp_attach_single_file_db yourDBName,'d:\mssql7\data\yourDBName_datamdf'
--以单文件的方式注册该DB,如果成功则MSSQL将自动为这个DB生成一个500K的日志文件。
以上方法在清除log日志中均有效。
但,能否让sql server 不产生log日志呢?以上方法好像均无效。
我这儿正好有个case:
我客户的sql server每天都会产生4,500M的log日志,每天都清除一下,非常不便。有没有办法实现不产生log日志呢?
我分析了一下客户产生log日志的原因,并且做了相应测试。
客户是每天将数据库清空,从总系统中将数据导入到sql server里。我感决sqlserver在插入时产生log不大,在delete整个库时产生log极大。
比如:
SELECT into test_2 from b_bgxx
共45000条记录,产生十几M log,如果
delete from test_2
产生80多M log ,这明显存在问题。
虽然可以换成:
truncate table test_2
但我还是希望能找到不产生log的方法。就如oracle不产生归档一样。
打开论坛根目录的DTNconfig,修改<Dbconnectstring>这个节点内容,在“Data
Source=“之后加上你数据库的IP地址,“User
ID=”之后加上你的数据库用户名,“Password=“之后加上你的数据库访问密码,“Initial
Catalog=”之后加上你的数据库名,后面的“Pooling=true”不用修改。
例如:<Dbconnectstring>Data
Source=14529738;User
ID=sa;Password=123;Initial
Catalog=dnt35b;Pooling=true</Dbconnectstring>
以上就是关于Discuz! Database Error 怎么办怎么办、论坛打不开。。全部的内容,包括:Discuz! Database Error 怎么办怎么办、论坛打不开。。、discuz论坛为什么打不开数据库、论坛出现这样的错误是怎么回事Microsoft OLE DB Provider for SQL Server 错误 '80040e14'等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)