SQL Server数据库实例间迁移Login
SQL Server数据库实例间迁移Login
1. 流行的方法:T-SQL
老式的方法是,准备好CREATE LOGIN脚本,填入账号和密码,保持SID一致,在新服务器实例上执行。
微软在KB918992和KB246133也提供了2个存储过程来解决各种版本间Login迁移问题。不同版本使用不同的方案。
注意密码的哈希有以下两个版本:
VERSION_SHA1:使用SHA1算法产生的哈希,用于SQL Server 2000到SQL Server 2008 R2。
VERSION_SHA2:使用SHA2 512算法产生的哈希,用于SQL Server 2012到之后的版本。
对于SQL Server 2012及之后的版本,需要手工修改KB918992脚本中哈希变量长度:
替换256为512
替换514为1028
替换1024为2048
示例语法:
EXEC dbo.sp_help_revlogin --OR EXEC dbo.sp_help_revlogin @login_name = 'BlogTester' -- sysname
示例输出:
/* sp_help_revlogin script ** Generated Aug 20 2012 8:24AM on V-DEV-DB-011\vb18 */ -- Login: BlogTester CREATE LOGIN [BlogTester] WITH PASSWORD = 0x01000D1F43BB2A1F306EC90F5352291E8DD273549DB4AF950845 HASHED, SID = 0xD831296B0274D448A5748A52B8C796EA, DEFAULT_DATABASE = [master], CHECK_POLICY = OFF, CHECK_EXPIRATION = OFF
2. 少用的方法:SSIS的Transfer Logins Task
SQL Server Data Tools提供了Transfer Logins Task任务,我们可以迁移所有Logins,一个Login,选择特定的Logins集合。我们也可以配置当Login存在的时候覆盖、跳过或抛出错误。详见Technet文章。
3. 新潮的方法:Powershell的Copy-SqlLogin和Export-SqlLogin
Copy-SqlLogin和Export-SqlLogin并不是微软官方的SQL Server模块的cmdlet,因此,你先要安装dbatools模块:
http://dbatools.io/getting-started
然后执行Login导出:
Export-SqlLogin -SqlServer sql2005 -FileName C:\temp\sql2005-logins.sql
默认,Export-SqlLogin导出所有的Login,也也可以选择包含或排除的Login。
或者,你想从SQL Server 2000动态迁移Login到SQL Server 2016?
Copy-SqlLogin -Source sqlsvr2000 -Destination newsql2016
Copy-SqlLogin可以运行在SQL Server 2000到2016。
如果想同步可用性组的Login权限,怎么做呢?dbatools模块提供了Sync-SqlLoginPermissions cmdlet来做这个工作。不像Copy-SqlLogin,Sync-SqlLoginPermissions不添加新Login。它只是同步实例和数据库权限集合,以及实例和数据库角色和作业所有者。
Sync-SqlLoginPermissions -Source sql2005 -Destination sql2016
如果想拷贝可用性组的作业,怎么做呢?可以使用Copy-SqlJob。
参考:
http://www.sqlhammer.com/how-to-transfer-logins-to-a-new-server/
https://blog.netnerds.net/2016/06/its-2016-why-is-sp_help_revlogin-a-thing/
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
ActiveMQ从入门到精通(一)
这是关于消息中间件ActiveMQ的一个系列专题文章,将涵盖JMS、ActiveMQ的初步入门及API详细使用、两种经典的消息模式(PTP and Pub/Sub)、与Spring整合、ActiveMQ集群、监控与配置优化等。话不多说,我们来一起瞧一瞧! JMS 首先来说较早以前,也就是没有JMS的那个时候,很多应用系统存在一些缺陷: 1.通信的同步性 client端发起调用后,必须等待server处理完成并返回结果后才能继续执行 2.client 和 server 的生命周期耦合太高 client进程和server服务进程都必须可用,如果server出现问题或者网络故障,那么client端会收到异常 3.点对点通信 client端的一次调用只能发送给某一个单独的服务对象,无法一对多 JMS,即Java Message Service,通过面向消息中间件(MOM:Message Oriented Middleware)的方式很好的解决了上面的问题。大致的过程是这样的:发送者把消息发送给消息服务器,消息服务器将消息存放在若干队列/主题中,在合适的时候,消息服务器会将消息转发给接受者。在这...
- 下一篇
SQLT导入测试数据,及SQL Profile的使用
性能分析过程中,经常会遇到生产库出现SQL的性能问题,但是,我们没有办法在生产库上做很多动作,需要将这个SQL的对应的表结构信息,统计信息导入到测试库进行测试(没有真实的测试数据,只有统计信息) 本次测试目的,客户环境导出了Test和product环境的相同SQL的不同执行计划的SQLT报告。 TEST环境是11.2.0.1版本 Product是11.2.0.2版本 我们会将两个SQLT报告分别导入到11.2.0.1和11.2.0.2的测试环境中,然后将11.2.0.1版本,好的执行计划,作为profile导出到11.2.0.2中。让11.2.0.2也根据11.2.0.1中的SQL一样,使用相同的执行计划。 ~~~~~~~第一部分,导入testcase环境,只导入统计信息,和表的元数据。没有真实数据~~~~~~ 1. 参考sqlt_s39917_readme.html(客户SQLT输出的文件中,就已经包含这个readme.html文件) 也可以参考文档How to Use SQLT (SQLTXPLAIN) to Create a Testcase Without Row Dat...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 2048小游戏-低调大师作品
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS8安装Docker,最新的服务器搭配容器使用
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池