EXEC <DatabaseName>..sp_adduser
можно запустить из соединения с любой базой данных (даже, скажем, master
). Соединение не будет затронуто.
Например, в моей системе работает нормально:
USE master
EXEC sp_addlogin 'test1'
EXEC SandBox..sp_adduser 'test1'
То же самое работает через клиента. Изменяет ли ваше клиентское соединение ваш SQL?
using System;
using System.Data.SqlClient;
namespace TestUse
{
class Program
{
static void Main(string[] args)
{
SqlConnection cn = new SqlConnection("Server=(local);Database=master;Trusted_Connection=True;");
cn.Open();
SqlCommand cmd = new SqlCommand("USE master; EXEC sp_addlogin 'test1'; EXEC SandBox..sp_adduser 'test1'", cn);
cmd.ExecuteNonQuery();
cn.Close();
}
}
}