由于误删除master库中的syslogins表导致用户不能登录数据库,不过有master数据库的备份,尝试恢复,总结步骤如下。
1 备份master数据库
dump database master to 'e:\backup\master.dat'
2 重新创建master设备大小(重新创建前,先删除以前的master设备)
sqlsrvr -d g:\master.dat -b500M
3 以恢复方式启动sybase服务
sqlsrvr -dg:\master.dat -sDY -eg:\sybase\ASE-12_5\install\errorlog -ig:\sybase\ini -Mg:\sybase -m
-d 指定master设备的名字
-b 指定master设备的大小
-s 服务名
-e 错误日志文件名
-i 接口文件的目录
-M 指定sybases主安装目录就行
-m master的恢复模式,也就是master的单用户模式。
4 指定master数据库的大小
alter database master on master = '280M'
5 确定并更改sysservers 表中关于备份服务的网络名为备份服务名。
注意可以直接更新系统表,不需要sp_configure ‘allow update’,1
select * from sysservers
update sysservers set srvnetname='crm_bs' where srvid=1
6 启动sybase的备份服务
7 load master数据库的备份
load database master from 'e:\backup\master.dat'
8 重启sybase主服务
本文转自 zhangxuwl 51CTO博客,原文链接:http://blog.51cto.com/jiujian/1046842,如需转载请自行联系原作者