欢迎来到天天文库
浏览记录
ID:5878359
大小:112.50 KB
页数:3页
时间:2017-12-27
《sqlserver 附加数据库后出现只读或失败的解决方法》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、解决此问题的几个关键点如下:1、该现象只会出现在NTFS文件系统中。2、由NTFS文件系统的访问权限导致。一般手工操作的解决方案如下:1、控制面板—>文件夹选项—>查看关闭“使用简单文件共享(推荐)”2、选择存放数据库文件的文件夹,右键选择属性,这时会多出一个“安全”选项卡,选择最后一个用户,将该用户的权限设为“完全控制”。经过这两步操作后,数据库附加失败或附加后只读的问题即可解决。下面重点讲这两步,用C#代码的实现,因为当我们为项目打包后,不可能让用户手工来执行这些操作1、C#关闭简单文件共享的代码实现在百度、Google搜索此问题解决方法时,很多的操作方法并不正确,经过自己实际
2、操作测试,正确方法如下:注册表文件:WindowsRegistryEditorVersion5.00[HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlLsa]"forceguest"=dword:00000000批处理:regaddHKLMSYSTEMCurrentControlSetControlLsa/vforceguest/tREG_WORD/d0x00000000/f如果选中此项,则将上述0x00000000改为0x00000001。通过修改注册表的方式实现代码如下:Microsoft.Win32.Regist
3、ryKeykey=Microsoft.Win32.Registry.LocalMachine;Microsoft.Win32.RegistryKeysoftware=key.OpenSubKey(@"SYSTEMCurrentControlSetControlLsa",true);software.SetValue("forceguest",0);2、C#修改指定文件夹的用户访问权限代码实现如下:(将该用户的权限设置为可写)stringpath=this.Context.Parameters["targetdir"];//得到文件夹路径DirectoryInfodInfo=n
4、ewDirectoryInfo(path);DirectorySecuritydSecurity=dInfo.GetAccessControl();dSecurity.AddAccessRule(newFileSystemAccessRule(Environment.UserName,FileSystemRights.CreateFiles,AccessControlType.Allow));dInfo.SetAccessControl(dSecurity);
此文档下载收益归作者所有