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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

MySQL中VARCHAR和TEXT的区别小结

《MySQL中VARCHAR和TEXT的区别小结》MySQL中VARCHAR和TEXT用于存储字符串,VARCHAR可变长度存储在行内,适合短文本;TEXT存储在溢出页,适合大文本,下面就来具体的了解... 目录一、VARCHAR 和 TEXT 基本介绍1. VARCHAR2. TEXT二、VARCHAR

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

MySQL中C接口的实现

《MySQL中C接口的实现》本节内容介绍使用C/C++访问数据库,包括对数据库的增删查改操作,主要是学习一些接口的调用,具有一定的参考价值,感兴趣的可以了解一下... 目录准备mysql库使用mysql库编译文件官方API文档对象的创建和关闭链接数据库下达sql指令select语句前言:本节内容介绍使用C/

mybatis直接执行完整sql及踩坑解决

《mybatis直接执行完整sql及踩坑解决》MyBatis可通过select标签执行动态SQL,DQL用ListLinkedHashMap接收结果,DML用int处理,注意防御SQL注入,优先使用#... 目录myBATiFBNZQs直接执行完整sql及踩坑select语句采用count、insert、u

MySQL之搜索引擎使用解读

《MySQL之搜索引擎使用解读》MySQL存储引擎是数据存储和管理的核心组件,不同引擎(如InnoDB、MyISAM)采用不同机制,InnoDB支持事务与行锁,适合高并发场景;MyISAM不支持事务,... 目录mysql的存储引擎是什么MySQL存储引擎的功能MySQL的存储引擎的分类查看存储引擎1.命令