sqlserver 登录名和账户复制一套代码

2024-06-05 13:38

本文主要是介绍sqlserver 登录名和账户复制一套代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先要执行准备签的临时表和自定义随机值函数的创建

直接建在master下,数据库就都能使用了,但一定要有高权限才行

use master;
go
create view v_random as select newid() as MacoId; goCREATE TABLE privs_test
(
Ownername varchar (300) COLLATE Chinese_PRC_CI_AS NULL,
tablename varchar (300) COLLATE Chinese_PRC_CI_AS NULL,
usernm varchar (300) COLLATE Chinese_PRC_CI_AS NULL,
grantor varchar (300) COLLATE Chinese_PRC_CI_AS NULL,
typename varchar (300) COLLATE Chinese_PRC_CI_AS NULL,
actionname varchar (300) COLLATE Chinese_PRC_CI_AS NULL,
clu varchar (300) COLLATE Chinese_PRC_CI_AS NULL
);GOcreate function [dbo].[m_rand](@mycount int)  
returns nvarchar(2000)  
as  
begin  declare @maco_wang table (id varchar(1))  declare @maco_number int,@number int;  declare @my_one nvarchar(max),@my_two nvarchar(max)  set @my_one='';set @maco_number=0; set @number =48;  while (@number>=48 and @number<=57) or (@number>=65 and @number<=90) or (@number>=97 and @number<=122)   begin  insert into @maco_wang select char(@number)  set @number=@number+1;  if(@number=58)  begin  set @number=65            end  if(@number=91)  begin       set @number=97     end  end  while @maco_number<@mycount  begin  select @my_two=id from @maco_wang  order by (select MacoId from dbo.v_random);  set @my_one=@my_two+@my_one;  set @maco_number=@maco_number+1;  end  return @my_one  
end;

创建XML大型语句,执行即可

--40
DECLARE
@Database varchar(555),
@sq4 nvarchar(max);--初始化
SET @sq4=N''DECLARE c_database CURSOR LOCAL  FOR SELECT name FROM  sysdatabases WHERE name  IN (需要循环的数据库) 
OPEN  c_database
FETCH NEXT FROM c_database INTO @Database
WHILE @@FETCH_STATUS = 0
BEGIN
SET @sq4=@sq4+N'
DECLARE
--用于用户
@loginName varchar(555),
@roleName varchar(555),
@sql nvarchar(max),
@sq2 nvarchar(max),
@newpasswd varchar(50),
@oldpasswd varchar(50),
--设置新账号
@newLoginname VARCHAR(50),
@Database varchar(555),--用于权限
@sq3 nvarchar(max),
@Owner varchar(100),
@tablename varchar(100),
@usernm varchar(100),
@grantor varchar(100),
@type varchar(100),
@actionname varchar(100),
@column varchar(100);--设置数据库
USE '+@Database+'SET @sql=N'''';
DECLARE curLogin CURSOR LOCAL for
select DB_NAME() as dbname,sp.name as username,dpr.name as rolename 
from sys.database_principals dp 
LEFT JOIN sys.database_role_members drm on drm.member_principal_id=dp.principal_id
LEFT JOIN sys.database_principals dpr on drm.role_principal_id=dpr.principal_id 
join sys.server_principals sp on sp.name=dp.name
where 1=1
--and dpr.is_fixed_role=1 
and sp.type =''S'' --SQL USER,WINDOWS USER AND windows group
AND sp.is_disabled =0
order by username,rolenameOPEN curLogin;FETCH NEXT FROM curLogin INTO @Database,@loginName,@roleName;WHILE @@FETCH_STATUS = 0
BEGIN
set @newpasswd=master.dbo.m_rand(30);
set @newLoginname=@LoginName+''2'';--新增登录名和用户
if not exists(select * from sys.server_principals where name=@newLoginname) 
BEGIN
SET @sql=@sql+N''
use ''+@Database+'';
print ''''账号: ''+@newLoginname+'' 密码: ''+@newpasswd+'''''';
CREATE login ''+QUOTENAME(@newLoginname)+'' with password=''''''+@newpasswd+''''''; 
CREATE USER ''+QUOTENAME(@newLoginname)+'' for login ''+QUOTENAME(@newLoginname)+'' ; 
'';
END;
else 
if not exists(select * from sys.database_principals where name=@newLoginname) 
BEGIN
SET @sql=@sql+N''
use ''+@Database+'';
CREATE USER ''+QUOTENAME(@newLoginname)+'' for login ''+QUOTENAME(@newLoginname)+''; 
'';end;
--处理角色权限
if @roleName IS NOT NULL
begin
select @sql=@sql+N''
exec sp_addrolemember ''+@roleName+'', '' + @newLoginname+''
''
END--处理用户单表权限
SET @usernm=@LoginName
set @sq3=''insert into master.dbo.privs_test exec sp_helprotect @username = ''+@usernm+'''';
EXEC sp_executesql @sq3
DECLARE tableprivs CURSOR LOCAL FOR select Ownername,tablename,usernm,grantor,typename,actionname,clu from master.dbo.privs_test WHERE Ownername not in (''.'') AND tablename not in (''.'')
OPEN tableprivs;FETCH NEXT FROM tableprivs INTO @Owner,@tablename,@usernm,@grantor,@type,@actionname,@column;
WHILE @@FETCH_STATUS = 0
BEGIN
set @sql=@sql+N''
grant ''+@actionname+'' on ''+@tablename+'' to ''+@newLoginname+'';
''
FETCH NEXT FROM tableprivs INTO @Owner,@tablename,@usernm,@grantor,@type,@actionname,@column;
END
CLOSE tableprivs
DEALLOCATE tableprivs;--修改原登录名密码
--SET @sql=@sql+N''ALTER LOGIN ''+@LoginName+'' with passward= ''+@oldpasswd+'' '';--继续循环游标
FETCH NEXT FROM curLogin INTO @Database,@loginName,@roleName;
truncate TABLE master.dbo.privs_test 
ENDCLOSE curLogin
DEALLOCATE curLogin;SELECT @sql FOR XML PATH(''test'')
exec sp_executesql @sql
GO
'
FETCH NEXT FROM c_database INTO @Database
end
CLOSE c_database
DEALLOCATE c_database
SELECT @sq4 FOR XML PATH('test1')

 

这篇关于sqlserver 登录名和账户复制一套代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1033215

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误