解决SQL2000删除用户时提示'因为选定的用户拥有对象,所以无法除去该用户'

需积分: 9 2 下载量 109 浏览量 更新于2024-09-15 收藏 89KB DOC 举报
"在SQL Server 2000中,当尝试删除一个用户时,如果该用户拥有数据库中的对象,系统会阻止删除操作,显示‘因为选定的用户拥有对象,所以无法除去该用户’的错误信息。这个问题通常发生在数据库还原后,用户需要删除并重新配置用户,但操作受阻。解决此问题需要对SQL Server的系统表进行直接修改。" 在SQL Server 2000中,用户与数据库对象的权限管理是严格控制的。当用户拥有数据库中的表、视图、存储过程等对象时,系统不允许直接删除该用户,因为这会导致对象失去所有者,从而破坏数据库的完整性。以下是解决这个问题的步骤: 1. 打开SQL Server企业管理器,展开服务器节点,然后右键单击本地服务器,选择“属性”。 2. 在SQL Server属性(配置)窗口中,切换到“常规”选项卡,勾选“自动启动SQL Server代理”,然后点击“确定”。 3. 再次打开SQL Server属性(配置)窗口,这次选择“服务器设置”选项卡,勾选“允许对系统目录直接进行修改”,再次点击“确定”。 4. 展开“数据库”节点,找到数据库系统表`sysusers`,右键选择“打开表”然后“返回所有行”。 5. 在`sysusers`表中找到需要删除的用户行,右键选择“删除”。完成删除后,检查用户列表确认用户已被移除。 6. 如果需要,可以在SQL Server的安全管理中,将该用户添加回数据库,确保业务的正常运行。 7. 最后,再次进入SQL Server属性(配置)窗口,取消勾选“允许对系统目录直接进行修改”,以恢复默认的安全设置。 此外,还有一种替代方法是将用户拥有的所有对象的所有权转移给`dbo`用户。通过执行SQL语句,例如`ALTER AUTHORIZATION ON OBJECT::object_name TO dbo;`,将每个对象的所有权转移后,就可以安全地删除用户了。 注意,直接修改系统表是一种高级操作,可能会对数据库的稳定性产生影响,因此在进行此类操作时务必谨慎,且最好在备份数据库之后进行。只有在标准方法无法解决问题时,才应考虑这种方法。在日常管理中,应遵循最佳实践,避免不必要的直接系统表修改,以确保数据的安全性和系统的可维护性。
2024-07-20 上传
微信小程序的社区门诊管理系统流程不完善导致小程序的使用率较低。社区门诊管理系统的部署与应用,将对日常的门诊信息、预约挂号、检查信息、检查报告、病例信息等功能进行管理,这可以简化工作程序、降低劳动成本、提高工作效率。为了有效推动医院的合理配置和使用,迫切需要研发一套更加全面的社区门诊管理系统。 本论文主要介绍基于Php语言设计并实现了微信小程序的社区门诊管理系统。该小程序基于B/S即所谓浏览器/服务器模式,选择MySQL作为后台数据库去开发并实现一个以微信小程序的社区门诊为核心的系统以及对系统的简易介绍。 本课题要求实现一套微信小程序的社区门诊管理系统,系统主要包括管理员模块和用户模块、医生模块功能模块。 用户注册,在用户注册页面通过填写账号、密码、确认密码、姓名、性别、手机、等信息进行注册操作。用户登陆微信端后,可以对首页、门诊信息、我的等功能进行详细操作。门诊信息,在门诊信息页面可以查看科室名称、科室类型、医生编号、医生姓名、 职称、坐诊时间、科室图片、点击次数、科室介绍等信息进行预约挂号操作。检查信息,在检查信息页面可以查看检查项目、检查地点、检查时间、检查费用、账号、姓名、医生编号、医生姓名、是否支付、审核回复、审核状态等信息进行支付操作。我的,在我的页面可以对预约挂号、检查信息、检查报告、处方信息、费用信息等详细信息。 管理员登录进入社区门诊管理系统可以查看首页、个人中心、用户管理、医生管理、门诊信息管理、科室分类管理、预约挂号管理、检查信息管理、检查报告管理、病例信息管理、处方信息管理、费用信息管理、系统管理等信息进行相应操作。 医生登录进入社区门诊管理系统可以查看首页、个人中心、预约挂号管理、检查信息管理、检查报告管理、病例信息管理、处方信息管理等信息进行相应操作。