2010-03-04

所谓孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslogins中却没有对应的记录。

孤立帐户的产生一般是一下两种:
1.将备份的数据库在其它机器上还原;
2.重装系统或SQL SERVER之后只还原了用户库

解决方法是使用sp_change_users_login来修复。

sp_change_users_login的用法有三种

用法1:
exec sp_change_users_login 'REPORT'

列出当前数据库的孤立用户

用法2:
exec sp_change_users_login 'AUTO_FIX','用户名'

可以自动将用户名所对应的同名登录添加到syslogins中

用法3:
exec sp_change_users_login 'UPDATE_ONE','用户名','登录名'
将用户名映射为指定的登录名。

CREATE TABLE Sailors (Sid char(10)PRIMARY KEY, sname char(20), rating int , age int ); CREATE TABLE Boats (bid char(10)PRIMARY KEY, bname char(20) NOT NULL, color char(10) ); CREATE TABLE Reserves (Sid char(10) , bid char(10), rdate date, PRIMARY KEY(Sid,bid,rdate), FOREIGN KEY(Sid)REFERENCES Sailors(Sid), FOREIGN KEY(bid)REFERENCES Boats(bid), ); insert into Sailors (Sid ,Sname,rating,age ) values ('22','dustin',7,45), ('29','brustus',1,33), ('31','lubber',8,56), ('32','andy',8,26), ('58','rusty',10,35), ('64','horati',7,35), ('71','zorba',10,35), ('74','horatio',9,35), ('85','art',3,26), ('86','john',1,17), ('95','bob',3,64), ('96','frodo',3,26), ('98','tom',3,17); insert into Boats (bid ,bname ,color ) values (101 , 'A' , 'red'), (102 , 'B' , 'green' ), (103 , 'C' , 'blue '), (104 , 'D' , 'white') , (105 , 'E' , 'red '), (106 , 'F' , 'blue '), (107 , 'G' , 'green') ; insert into Reserves (Sid ,bid ,rdate ) values ( 22 , 101 , '2010-01-08' ), ( 22 , 102 , '2010-01-09' ), ( 29 , 103 , '2010-01-09' ), ( 31 , 102 , '2010-02-11' ), ( 22 , 104 , '2010-03-08' ), ( 22 , 103 , '2010-03-10' ), ( 32 , 105 , '2010-03-11' ), ( 32 , 106 , '2010-03-18' ), ( 32 , 102 , '2010-03-19' ), ( 58 , 104 , '2010-03-20' ), ( 64 , 105 , '2010-03-20' ), ( 95 , 101 , '2010-04-02' ), ( 85 , 102 , '2010-04-05' ), ( 22 , 101 , '2010-04-07' ), ( 22 , 105 , '2010-05-01' ), ( 22 , 106 , '2010-06-18' ), ( 22 , 107 , '2010-07-09' ), ( 31 , 106 , '2010-08-06' ), ( 32 , 105 , '2010-08-06' ), ( 29 , 104 , '2010-08-07' ), ( 64 , 103 , '2010-09-05' ), ( 58 , 102 , '2010-09-09' ), ( 64 , 104 , '2010-11-03' ), ( 64 , 105 , '2010-11-04' ), ( 31 , 106 , '2010-12-06' );
最新发布
03-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值