Maison base de données tutoriel mysql MSSQL数据库迁移之用户名问题

MSSQL数据库迁移之用户名问题

Jun 07, 2016 pm 06:00 PM
mssql 数据库迁移

数据库A有用户A,有一些用户A创建的表和SP。迁移时将data目录下的MDF和LDF移到新的MSSQL服务器上,通过附加数据库的功能将数据库恢复。

但是,此时用户A存在于数据库A中,而新的MSSQL中虽然能创建用户A,但无法把权限赋于用户A。新创建一个用户B吧,用户A创建的表和其它信息就又无法访问。在这里找到了解决方法:
在源 SQL Server 上运行以下脚本。此脚本可在 master 数据库中创建名为 sp_hexadecimal 和 sp_help_revlogin 的两个存储过程。请在完成过程的创建之后继续执行第 2 步。
注意:下面的过程取决于 SQL Server 系统表。这些表的结构在 SQL Server 的不同版本之间可能会有变化,请不要直接从系统表中选择。
----- Begin Script, Create sp_help_revlogin procedure -----
代码如下:
USE master
GO
IF OBJECT_ID ('sp_hexadecimal') IS NOT NULL
DROP PROCEDURE sp_hexadecimal
GO
CREATE PROCEDURE sp_hexadecimal
@binvalue varbinary(256),
@hexvalue varchar(256) OUTPUT
AS
DECLARE @charvalue varchar(256)
DECLARE @i int
DECLARE @length int
DECLARE @hexstring char(16)
SELECT @charvalue = '0x'
SELECT @i = 1
SELECT @length = DATALENGTH (@binvalue)
SELECT @hexstring = '0123456789ABCDEF'
WHILE (@i BEGIN
DECLARE @tempint int
DECLARE @firstint int
DECLARE @secondint int
SELECT @tempint = CONVERT(int, SUBSTRING(@binvalue,@i,1))
SELECT @firstint = FLOOR(@tempint/16)
SELECT @secondint = @tempint - (@firstint*16)
SELECT @charvalue = @charvalue +
SUBSTRING(@hexstring, @firstint+1, 1) +
SUBSTRING(@hexstring, @secondint+1, 1)
SELECT @i = @i + 1
END
SELECT @hexvalue = @charvalue
GO
IF OBJECT_ID ('sp_help_revlogin') IS NOT NULL
DROP PROCEDURE sp_help_revlogin
GO
CREATE PROCEDURE sp_help_revlogin @login_name sysname = NULL AS
DECLARE @name sysname
DECLARE @xstatus int
DECLARE @binpwd varbinary (256)
DECLARE @txtpwd sysname
DECLARE @tmpstr varchar (256)
DECLARE @SID_varbinary varbinary(85)
DECLARE @SID_string varchar(256)
IF (@login_name IS NULL)
DECLARE login_curs CURSOR FOR
SELECT sid, name, xstatus, password FROM master..sysxlogins
WHERE srvid IS NULL AND name 'sa'
ELSE
DECLARE login_curs CURSOR FOR
SELECT sid, name, xstatus, password FROM master..sysxlogins
WHERE srvid IS NULL AND name = @login_name
OPEN login_curs
FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @xstatus, @binpwd
IF (@@fetch_status = -1)
BEGIN
PRINT 'No login(s) found.'
CLOSE login_curs
DEALLOCATE login_curs
RETURN -1
END
SET @tmpstr = '/* sp_help_revlogin script '
PRINT @tmpstr
SET @tmpstr = '** Generated '
+ CONVERT (varchar, GETDATE()) + ' on ' + @@SERVERNAME + ' */'
PRINT @tmpstr
PRINT ''
PRINT 'DECLARE @pwd sysname'
WHILE (@@fetch_status -1)
BEGIN
IF (@@fetch_status -2)
BEGIN
PRINT ''
SET @tmpstr = '-- Login: ' + @name
PRINT @tmpstr
IF (@xstatus & 4) = 4
BEGIN -- NT authenticated account/group
IF (@xstatus & 1) = 1
BEGIN -- NT login is denied access
SET @tmpstr = 'EXEC master..sp_denylogin ''' + @name + ''''
PRINT @tmpstr
END
ELSE BEGIN -- NT login has access
SET @tmpstr = 'EXEC master..sp_grantlogin ''' + @name + ''''
PRINT @tmpstr
END
END
ELSE BEGIN -- SQL Server authentication
IF (@binpwd IS NOT NULL)
BEGIN -- Non-null password
EXEC sp_hexadecimal @binpwd, @txtpwd OUT
IF (@xstatus & 2048) = 2048
SET @tmpstr = 'SET @pwd = CONVERT (varchar(256), ' + @txtpwd + ')'
ELSE
SET @tmpstr = 'SET @pwd = CONVERT (varbinary(256), ' + @txtpwd + ')'
PRINT @tmpstr
EXEC sp_hexadecimal @SID_varbinary,@SID_string OUT
SET @tmpstr = 'EXEC master..sp_addlogin ''' + @name
+ ''', @pwd, @sid = ' + @SID_string + ', @encryptopt = '
END
ELSE BEGIN
-- Null password
EXEC sp_hexadecimal @SID_varbinary,@SID_string OUT
SET @tmpstr = 'EXEC master..sp_addlogin ''' + @name
+ ''', NULL, @sid = ' + @SID_string + ', @encryptopt = '
END
IF (@xstatus & 2048) = 2048
-- login upgraded from 6.5
SET @tmpstr = @tmpstr + '''skip_encryption_old'''
ELSE
SET @tmpstr = @tmpstr + '''skip_encryption'''
PRINT @tmpstr
END
END
FETCH NEXT FROM login_curs INTO @SID_varbinary, @name, @xstatus, @binpwd
END
CLOSE login_curs
DEALLOCATE login_curs
RETURN 0
GO

----- End Script -----
2. 在创建 sp_help_revlogin 存储过程后,请从源服务器上的查询分析器中运行 sp_help_revlogin 过程。sp_help_revlogin 存储过程可同时用于 SQL Server 7.0 和 SQL Server 2000。sp_help_revlogin 存储过程的输出是登录脚本,该脚本可创建带有原始 SID 和密码的登录。保存输出,然后将其粘贴到目标 SQL Server 上的查询分析器中,并运行它。例如:EXEC master..sp_help_revlogin
代码如下:SP_DEFAULTDB 'cyiyun','DB_WAYUP'
第1步后,在源服务器上运行sp_help_revlogin后,会产生创建用户数据的SQL,例如:
代码如下:
/* sp_help_revlogin script
** Generated 06 24 2009 1:40PM on WORKGROU-B1XTVC */
DECLARE @pwd sysname
-- Login: hxtest
SET @pwd = CONVERT (varbinary(256), 0x0100CF4E7D342B359438E4BCCA72E6C83F44FCCF30C8016286DE2B359438E4BCCA72E6C83F44FCCF30C8016286DE)
EXEC master..sp_addlogin '520web', @pwd, @sid = 0x1738BB6AD0CD24498F67FB5589E8EDCB, @encryptopt = 'skip_encryption'
......

把这段直接在新服务器上运行,或者找到相应的用户名创建,就可以解决这个问题了!
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment connecter PHP à la base de données mssql Comment connecter PHP à la base de données mssql Oct 23, 2023 pm 12:02 PM

Les méthodes permettant à PHP de se connecter à la base de données mssql incluent l'utilisation de l'extension MSSQL de PHP, l'utilisation de PDO, etc. Introduction détaillée : 1. Utilisez la méthode d'extension MSSQL de PHP pour vous assurer que l'extension MSSQL est installée sur PHP. Vous pouvez vérifier si l'extension mssql est activée dans le fichier de configuration PHP (php.ini) ; 2. Utilisez la méthode PDO pour vous assurer que PHP a l'extension PDO installée. Vous pouvez vérifier si l'extension pdo_sqlsrv est activée dans le fichier de configuration PHP (php.ini).

Guide détaillé pour installer PHP et configurer la connexion MSSQL sur Ubuntu Guide détaillé pour installer PHP et configurer la connexion MSSQL sur Ubuntu Feb 29, 2024 am 11:15 AM

Ubuntu est un système d'exploitation open source populaire couramment utilisé pour exécuter des serveurs. L'installation de PHP et la configuration des connexions MSSQL sur Ubuntu sont l'une des opérations que de nombreux développeurs et administrateurs système doivent souvent effectuer. Cet article fournira aux lecteurs un guide détaillé, comprenant les étapes pour installer PHP, configurer Apache, installer MSSQLServer, etc., et joindre des exemples de code spécifiques. Étape 1 : Installer PHP et les extensions associées. Tout d'abord, nous devons installer PHP et les extensions associées pour prendre en charge les connexions PHP.

Conseils de migration de base de données dans le framework Django Conseils de migration de base de données dans le framework Django Jun 17, 2023 pm 01:10 PM

Django est un framework de développement Web écrit en Python. Il fournit de nombreux outils et modules pratiques pour aider les développeurs à créer rapidement des sites Web et des applications. L'une des fonctionnalités les plus importantes est la fonction de migration de base de données, qui peut nous aider à gérer simplement les modifications du schéma de base de données. Dans cet article, nous présenterons quelques conseils pour utiliser la migration de base de données dans Django, notamment comment démarrer une nouvelle migration de base de données, comment détecter les conflits de migration de base de données, comment afficher les enregistrements historiques de migration de base de données, etc.

Explication détaillée des étapes pour installer PHP pour prendre en charge la base de données MSSQL dans l'environnement Ubuntu Explication détaillée des étapes pour installer PHP pour prendre en charge la base de données MSSQL dans l'environnement Ubuntu Feb 29, 2024 am 10:39 AM

Étapes détaillées pour installer PHP pour prendre en charge la base de données MSSQL dans l'environnement Ubuntu. Lors du développement d'applications Web, vous rencontrez souvent des situations dans lesquelles vous devez vous connecter à la base de données Microsoft SQL Server (MSSQL). Dans l'environnement Ubuntu, pour connecter PHP à la base de données MSSQL, vous devez installer le logiciel approprié et configurer les paramètres appropriés. Ensuite, nous présenterons en détail les étapes pour installer PHP pour prendre en charge la base de données MSSQL dans l'environnement Ubuntu et fournirons un code spécifique.

Étapes pour implémenter les migrations de bases de données (Migrations) à l'aide du framework Zend Étapes pour implémenter les migrations de bases de données (Migrations) à l'aide du framework Zend Jul 28, 2023 pm 05:54 PM

Étapes pour implémenter les migrations de bases de données (Migrations) à l'aide du framework Zend Introduction : La migration de bases de données fait partie intégrante du processus de développement logiciel. Sa fonction est de faciliter la modification et le contrôle de version par l'équipe de la structure de la base de données pendant le développement. Le Zend Framework fournit un ensemble puissant d'outils de migration de bases de données qui peuvent nous aider à gérer facilement les modifications apportées à la structure de la base de données. Cet article présentera les étapes d'utilisation du framework Zend pour implémenter la migration de bases de données et joindra des exemples de code correspondants. Étape 1 : Installez Zend Framework en premier

PHP et SQLite : Comment effectuer des migrations et des mises à niveau de bases de données PHP et SQLite : Comment effectuer des migrations et des mises à niveau de bases de données Jul 28, 2023 pm 08:10 PM

PHP et SQLite : Comment effectuer la migration et la mise à niveau de bases de données La migration et la mise à niveau de bases de données sont une tâche très courante lors du développement d'applications Web. Pour les développeurs utilisant PHP et SQLite, ce processus peut être plus compliqué. Cet article explique comment utiliser PHP et SQLite pour la migration et la mise à niveau de bases de données, et fournit quelques exemples de code à titre de référence. Créer une base de données SQLite Tout d'abord, nous devons créer une base de données SQLite. Utiliser la base de données SQLite est très pratique, nous

Tutoriel complet sur l'installation de PHP et la connexion à la base de données MSSQL sous Ubuntu Tutoriel complet sur l'installation de PHP et la connexion à la base de données MSSQL sous Ubuntu Feb 29, 2024 am 11:18 AM

L'installation de PHP et la connexion à la base de données MSSQL sous le système d'exploitation Ubuntu sont l'une des compétences que de nombreux développeurs et administrateurs système doivent maîtriser. Cet article fournira un didacticiel détaillé, comprenant l'installation de PHP, l'installation du pilote côté serveur MSSQL, la configuration de PHP pour se connecter à la base de données MSSQL et la fourniture d'exemples de code correspondants. Première partie : installer PHP Tout d'abord, nous devons installer PHP et les extensions associées pour pouvoir nous connecter à la base de données MSSQL. Entrez la commande suivante dans le terminal pour installer PHP et les extensions nécessaires

Comment migrer la base de données MySQL Comment migrer la base de données MySQL Feb 21, 2024 pm 04:00 PM

La migration de base de données MySQL fait référence au processus de migration des données et des structures d'une base de données vers une autre base de données. Dans les projets réels, vous pouvez rencontrer des situations dans lesquelles vous devez migrer la base de données vers un nouveau serveur, mettre à niveau la version de la base de données, fusionner plusieurs bases de données, etc. Ce qui suit présentera comment migrer la base de données MySQL et fournira des exemples de code spécifiques. Exportez la base de données d'origine. Tout d'abord, utilisez l'outil d'exportation sur le serveur sur lequel se trouve la base de données d'origine pour exporter les données et la structure dans un fichier SQL. Les outils d'exportation couramment utilisés incluent la commande mysqldump

See all articles