SQL SERVER “用户、组或角色'dev'在当前数据库中已存在”的解决办法

一般在还原数据库后,给这个数据库添加一个登录名时出现。

例如数据库备份文件中已经包含了用户dev,现在还原了数据库,然后发现现有数据库中没有abc这个用户,想要新建一个dev用户,作为该数据库的owner,便会出现这个问题。


可以理解为登录名和用户是两个不同的概念,虽然名称相同。在新建登录名的时候,如果不添加该数据库映射则不会报错。

添加数据库映射相当于给该数据库添加一个同名用户。但是已经存在了dev这个用户了,所以此时会报错。

可以通过以下方法解决该问题。

1.新建一个dev登录名,但是不要添加数据库映射。

2.使用脚本,将孤立用户dev关联到登录名abc上:

Use [数据库名]

go

sp_change_users_login 'update_one', 'dev', 'dev'

要连接SQL Server数据库,需要使用ODBC驱动程序。ODBC(Open Database Connectivity)是一种标准的数据库访问方式,可以让不同的应用程序通过统一的接口来访问各种数据库。在Dev-C++,可以使用ODBC API来访问SQL Server数据库。 以下是连接SQL Server数据库的步骤: 1. 安装ODBC驱动程序。可以从Microsoft官网下载ODBC驱动程序。 2. 在Dev-C++创建一个新的项目。 3. 在项目设置,选择“Linker”选项卡,将odbc32.lib和user32.lib添加到链接器附加库。 4. 在代码包含头文件#include <windows.h>和#include <sql.h>。 5. 使用SQLAllocHandle函数分配句柄,使用SQLDriverConnect函数连接到数据库。 6. 使用SQLExecDirect函数执行SQL语句。 以下是一个示例代码,可以连接到SQL Server数据库并执行SQL查询: ```c++ #include <windows.h> #include <sql.h> int main() { SQLHENV env; //环境句柄 SQLHDBC dbc; //连接句柄 SQLHSTMT stmt; //语句句柄 SQLRETURN ret; //返回值 //分配环境句柄 ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env); //设置环境属性,告诉ODBC版本 ret = SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0); //分配连接句柄 ret = SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc); //连接数据库 ret = SQLDriverConnect(dbc, NULL, "DRIVER={SQL Server};SERVER=myServerName;DATABASE=myDataBaseName;UID=myUsername;PWD=myPassword;", SQL_NTS, NULL, 0, NULL, SQL_DRIVER_COMPLETE); if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO) { //执行SQL语句 ret = SQLAllocHandle(SQL_HANDLE_STMT, dbc, &stmt); ret = SQLExecDirect(stmt, "SELECT * FROM myTable", SQL_NTS); //处理结果 //... } //释放句柄 SQLFreeHandle(SQL_HANDLE_STMT, stmt); SQLDisconnect(dbc); SQLFreeHandle(SQL_HANDLE_DBC, dbc); SQLFreeHandle(SQL_HANDLE_ENV, env); return 0; } ``` 在连接字符串,需要替换myServerName、myDataBaseName、myUsername和myPassword为实际的SQL Server服务器名称、数据库名称、用户名和密码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值