关于sqlserver中master..database中的status:
在select * from master..sysdatabses中,有一项是status,表当前database的状况。
参数如下:
状态位,可以使用 ALTER DATABASE 设置其中的某些状态位,如下所示:
1 = autoclose (ALTER DATABASE)
4 = select into/bulkcopy(ALTER DATABASE,使用 SET RECOVERY)
8 = trunc. log on chkpt(ALTER DATABASE,使用 SET RECOVERY)
16 = torn page detection (ALTER DATABASE)
32 = loading
64 = pre recovery
128 = recovering
256 = not recovered
512 = offline (ALTER DATABASE)
1024 = read only (ALTER DATABASE)
2048 = dbo use only(ALTER DATABASE,使用 SET RESTRICTED_USER)
4096 = single user (ALTER DATABASE)
32768 = emergency mode
65536 = CHECKSUM (ALTER DATABASE)
4194304 = autoshrink (ALTER DATABASE)
1073741824 = cleanly shutdown
可以同时打开多个位。
from msdn
当我offline一个数据库的时候,发现它的值为:66048,后面查资料才知道这是由两个状态位相加得到的。
如: 66048 = 512 (offline) + 65536(checksum)
也同时注意msdn上说的也比较清楚, 可以同时打开多个位。
感谢这个贴: from CU