数据库为只读的解决方法

数据库为只读的解决方法

ID:19926202

大小:286.00 KB

页数:5页

时间:2018-10-07

数据库为只读的解决方法_第1页
数据库为只读的解决方法_第2页
数据库为只读的解决方法_第3页
数据库为只读的解决方法_第4页
数据库为只读的解决方法_第5页
资源描述:

《数据库为只读的解决方法》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、SQLServer2005Express附加的数据库为“只读”的解决方法问题:附加上数据库后,操作过程中遇到错误提示:数据库为“只读”。如下图:解决方案一:打开SQLServer数据库服务,右击打开SQLServerSQLEXPRESS的属性,如下图:将登陆身份选为内置账户:本地系统(localsystem)或如下图:在“内置帐号”处,把“网络服务”改成“本地系统”后,重新启动重启服务,重新分离附加数据库。  总结:之所以附加上的数据库为“只读”,是因为启动SQLServer的默认的启动帐号“网络服务”对所附加的数据库文件的权限不够造成的。解决方案二:当我们在附加SQLSer

2、ver数据库的时候,会出现附加失败,或附加成功后数据库是只读的。也会导致在安装和部署项目中的自动附加数据库操作失败。解决此问题的几个关键点如下:1、该现象只会出现在NTFS文件系统中。2、由NTFS文件系统的访问权限导致。一般手工操作的解决方案如下:1、控制面板—>文件夹选项—>查看关闭“使用简单文件共享(推荐)”2、选择存放数据库文件的文件夹,右键选择“属性”——“安全”选项卡,选择最后一个用户,将该用户的权限设为“完全控制”。经过这两步操作后,数据库附加失败或附加后只读的问题即可解决。解决方案三:用C#代码的实现,因为当我们为项目打包后,不可能让用户手工来执行这些操作1、

3、C#关闭简单文件共享的代码实现注册表文件:WindowsRegistryEditorVersion5.00[HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlLsa]"forceguest"=dword:00000000批处理:regaddHKLMSYSTEMCurrentControlSetControlLsa/vforceguest/tREG_WORD/d0x00000000/f如果选中此项,则将上述0x00000000改为0x00000001。通过修改注册表的方式实现代码如下:Microsoft.Win32.

4、RegistryKey key = Microsoft.Win32.Registry.LocalMachine;Microsoft.Win32.RegistryKey software = key.OpenSubKey(@"SYSTEMCurrentControlSetControlLsa", true);software.SetValue("forceguest", 0);2、C#修改指定文件夹的用户访问权限代码实现如下:(将该用户的权限设置为可写)string path = this.Context.Parameters["targetdir"];//得到文件夹路径

5、DirectoryInfo dInfo = new DirectoryInfo(path);DirectorySecurity dSecurity = dInfo.GetAccessControl();dSecurity.AddAccessRule(new FileSystemAccessRule(Environment.UserName, FileSystemRights.CreateFiles, AccessControlType.Allow));dInfo.SetAccessControl(dSecurity);

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。