TSQL将用户映射到数据库

TSQL将用户映射到数据库

问题描述:

因此,我无法使用企业管理器来执行此操作......如果我是我,我甚至不会问这个问题。所以我想知道是否有通过TSQL执行命令将用户映射到特定数据库并授予他们“所有者”权限的方法。TSQL将用户映射到数据库

谢谢...

更改默认的数据库:

alter login <loginname> with default_database = <dbname>; 

对于一个给定的登录在数据库中创建一个用户:

use <dbname>; 
create user <username> from login <loginname>; 

制作的db_owner组的用户成员:

use <dbname> 
exec sp_addrolemember 'db_owner', '<username>'; 

进行数据库登录'dbo':

alter authorization on database::<dbname> to <loginname>; 

正式,你想创建一个映射到一个登录的数据库用户。要做到这一点,你可以使用:

Create User <username> For LOGIN <loginname> 

这显然要求登录存在。之后,你会再调用:

exec sp_addrolemember 'db_owner', <username> 

这假设与您正在连接到数据库的帐户有权限的成员添加到db_owner作用。登录的

USE [YourDB] 
GO 
CREATE USER [xyx] FOR LOGIN [xyz] 
GO 
ALTER USER [xyz] WITH DEFAULT_SCHEMA=[dbo] 
GO 
EXEC sp_addrolemember N'db_owner', N'xyz' 
GO 

当然,通常情况下,您不希望授予用户所有者权限。这就是我们DBA世界中的那些人所说的“一件坏事”。

我对SQL的完整解决方案。

#region SQL-SERVER-FUNCTION 
    /// <summary> 
    /// Assign User in to specific role for SQL server database 
    /// </summary> 
    /// <param name="Server">Server address - example: yourServer.cloudapp.net,1433</param>   
    /// <param name="UserID">User name with sysadmin role</param> 
    /// <param name="Database">User database</param> 
    /// <param name="Role">New role for this user</param> 
    /// <param name="UserToRole">User assigned to new role</param> 
    public static void AddUserToRoles(string Server, string UserID, string Password, string Database, string Role, string UserToRole) 
    {    
     SqlConnection connection = new SqlConnection(); 
     connection.ConnectionString = "SERVER = " + Server + "; DATABASE = " + Database + " ; User ID = " + UserID + "; Pwd = " + Password;    
     string sqlCreateDBQuery = " EXEC sp_addrolemember '" + Role + "', " + UserToRole; 
     SqlCommand myCommand = new SqlCommand(sqlCreateDBQuery, connection); 
     try 
     { 
      connection.Open(); 
      myCommand.ExecuteNonQuery(); 
     } 
     catch{}//(System.Exception ex) 
     finally 
     { 
      connection.Close(); 
     } 
     return; 
    } 

    /// <summary> 
    /// Create new User in specified database base on Login in SQL server 
    /// </summary> 
    /// <param name="Server">Server address - example: yourServer.cloudapp.net,1433</param>   
    /// <param name="UserID">User name with sysadmin role</param> 
    /// <param name="Database">Database for created user</param> 
    /// <param name="NewUser">New user Name</param> 
    /// <param name="FromLogin">Create user base on this SQL server login</param> 
    public static void CreateUserInDatabase(string Server, string UserID, string Password, string Database, string NewUser, string FromLogin) 
    { 
     SqlConnection connection = new SqlConnection(); 
     connection.ConnectionString = "SERVER = " + Server + "; DATABASE = "+ Database + " ; User ID = " + UserID + "; Pwd = " + Password; 
     string sqlCreateDBQuery = "CREATE USER " + NewUser + " FROM LOGIN " + FromLogin;   
     SqlCommand myCommand = new SqlCommand(sqlCreateDBQuery, connection); 
     try 
     { 
      connection.Open(); 
      myCommand.ExecuteNonQuery(); 
     } 
     catch { }//(System.Exception ex) 
     finally 
     { 
      connection.Close(); 
     } 
     return; 
    } 

    /// <summary> 
    /// Create new Login in SQL server 
    /// </summary> 
    /// <param name="Server">Server address - example: yourServer.cloudapp.net,1433</param>   
    /// <param name="UserID">User name with sysadmin role</param> 
    /// <param name="Password">Sysadmin user password</param> 
    /// <param name="NewLoginName">New Login Name</param> 
    /// <param name="NewLoginPassword">Password for new Login</param>    
    public static void CreateLoginInSqlServer(string Server, string UserID, string Password, string NewLoginName, string NewLoginPassword) 
    { 
     SqlConnection connection = new SqlConnection(); 
     connection.ConnectionString = "SERVER = " + Server + "; DATABASE = master; User ID = " + UserID + "; Pwd = " + Password; 
     string sqlCreateDBQuery = "CREATE LOGIN [" + NewLoginName + "] WITH PASSWORD='"+ NewLoginPassword +"' " +    
      ", CHECK_POLICY=OFF, DEFAULT_DATABASE=db_crs_0002, DEFAULT_LANGUAGE=[English];";   
     SqlCommand myCommand = new SqlCommand(sqlCreateDBQuery, connection); 
     try 
     { 
      connection.Open(); 
      myCommand.ExecuteNonQuery(); 
     } 
     catch { }//(System.Exception ex) 
     finally 
     { 
      connection.Close(); 
     } 
     return; 
    } 


    /// <summary> 
    /// Create new empty database on SQL server base on model database stored in SQL server 
    /// </summary> 
    /// <param name="Server">Server address - example: yourServer.cloudapp.net,1433</param> 
    /// <param name="NewDatabaseName">Name for new database</param> 
    /// <param name="UserID">User name with sysadmin role</param> 
    /// <param name="Password">Sysadmin user password</param> 
    public static void CreateNewDatabaseSqlserver(string Server, string NewDatabaseName, string UserID, string Password)     
    { 
     string sqlCreateDBQuery = " CREATE DATABASE " + NewDatabaseName; 
     SqlConnection connection = new SqlConnection(); 
     connection.ConnectionString = "SERVER = " + Server + "; DATABASE = master; User ID = " + UserID + "; Pwd = " + Password; 
     SqlCommand myCommand = new SqlCommand(sqlCreateDBQuery, connection); 
     try 
     { 
      connection.Open(); 
      myCommand.ExecuteNonQuery(); 
     } 
     catch { }//(System.Exception ex) 
     finally 
     { 
      connection.Close(); 
     } 
     return; 
    } 
    #endregion 

使用: 具有sysadmin权限创建的SQL Server登录:AdminAPI

 SQLserverAPI.CreateNewDatabaseSqlserver("yourServer.cloudapp.net,1433", "databaseName", "AdminAPI", "password*"); 
     SQLserverAPI.CreateLoginInSqlServer("yourServer.cloudapp.net,1433", "AdminAPI", "password*", "My_Login", "password*"); 
     SQLserverAPI.CreateUserInDatabase("yourServer.cloudapp.net,1433", "AdminAPI", "password*", "databaseName", "User1", "My_Login"); 
     SQLserverAPI.AddUserToRoles("yourServer.cloudapp.net,1433", "AdminAPI", "password*", "databaseName", "db_datareader", "User1"); 
     SQLserverAPI.AddUserToRoles("yourServer.cloudapp.net,1433", "AdminAPI", "password*", "databaseName", "db_datawriter", "User1"); 
     SQLserverAPI.AddUserToRoles("yourServer.cloudapp.net,1433", "AdminAPI", "password*", "databaseName", "db_owner", "User1"); 
您可以根据您的需求进行定制