亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > SQL Server正確刪除Windows認證用戶的方法

SQL Server正確刪除Windows認證用戶的方法

熱門標簽:百度地圖標注不同路線 優質地圖標注 京華物流公司地圖標注 外呼系統電銷專用 智能語音外呼系統選哪家 武漢長沙外呼系統方法和技巧 奧威地圖標注多個地方 千呼電銷機器人價格 怎樣在地圖上標注路線圖標

前言

在SQL Server數據庫中,有時候會建立一些Windows認證的賬號(域賬號),例如,我們公司習慣給開發人員和Support同事開通NT賬號權限,如果有離職或負責事宜變更的話,那么要如何正確的刪除這些Windows認證賬號呢?這篇文章就是來探討一下如何正確的刪除Windows認證賬號。如下所示:

下面這種方式,僅僅是刪除登錄名(login),然而并沒有刪除用戶(User)

USE [master]
GO

DROP LOGIN [xxx\xxxx]
GO

你刪除登錄名的時候,就會遇到類似下面的告警信息:

Deleting server logins does not delete the database users associated with the logins. To complete the process, delete the users in each database. It may be necessary to first transfer the ownership of schemas to new users.

也就是說,雖然你刪除了登錄名,但是對應用戶數據庫或系統數據庫相關的User權限并沒有清理,在SQL Server中登錄名(Server Login)跟數據庫的用戶(database User)是分離開來,但是又有關聯的。所以正確的姿勢: 在刪除登錄名(login)后,還必須去每個數據庫,刪除對應的用戶(user). 在刪除登錄名前必須檢查,有那些作業的OWNER或數據庫的OWNER的為該Windows認證賬號(NT賬號),否則后面就會遇到一些問題:

1:如果刪除Windows認證用戶前,沒有修改作業的OWNER(如果此作業的OWNER為此Windows用戶的話,那么刪除Windows認證用戶后,作業就會報類似下面這種錯誤。

The job failed. The owner (xx\xxx) of job syspolicy_purge_history does not have server access.

所以在刪除Windows認證用戶前,必須檢查并修改作業的Owner,避免這種情況出現。

2:刪除Windows認證用戶前,確認是否有數據庫的OWNER為此Windows認證用戶。否則刪除登錄名時會報錯

Msg 15174, Level 16, State 1, Line 4

Login 'xxx\xxxx' owns one or more database(s). Change the owner of the database(s) before dropping the login.

Msg 15174, Level 16, State 1, Line 4

登錄名 'xxx\xxx' 擁有一個或多個數據庫。在刪除該登錄名之前,請更改相應數據庫的所有者。

必須修改數據庫的Owner后(一般將數據庫的owner改為sa),才能刪除登錄名

sp_changedbowner 'sa'

3:有時候刪除用戶時,報下面錯誤,必須修改后,才能刪除對應的用戶。

遇到下面錯誤:

Msg 15138, Level 16, State 1, Line 3

數據庫主體在該數據庫中擁有 架構,無法刪除。

Msg 15138, Level 16, State 1, Line 3

The database principal owns a schema in the database, and cannot be dropped.

USE YourSQLDba;

GO

ALTER AUTHORIZATION ON SCHEMA::[db_owner] TO [dbo];

USE [YourSQLDba]

GO

DROP USER [xxx\konglb];

GO

當然要根據實際情況來處理

USE [UserDatabase];

GO

ALTER AUTHORIZATION ON SCHEMA::[xxx] TO [dbo];

另外一種是用戶創建的Schema,這個根上面情況沒有差別。

所以正確的刪除登錄名,可以用腳本生成對應的SQL(當然也可以執行對應的SQL,但是這種高位操作,建議生成腳本,人工判斷后,手工執行)

DECLARE @login_name sysname;
SET @login_name='GFG1\chenzhenh'

SELECT d.name AS database_name,
owner_sid AS owner_sid ,
l.name AS database_owner
FROM sys.databases d
LEFT JOIN sys.syslogins l ON l.sid = d.owner_sid
WHERE l.name=@login_name;



SELECT 'USE ' + d.name + CHAR(10) 
+ 'GO' + CHAR(10)
+ 'EXEC dbo.sp_changedbowner @loginame =N''sa'', @map = false' AS change_db_owner_cmd
FROM sys.databases d
LEFT JOIN sys.syslogins l ON l.sid = d.owner_sid
WHERE l.name = @login_name;


SELECT j.job_id AS JOB_ID 
,j.name AS JOB_NAME 
,CASE WHEN [enabled] =1 THEN 'Enabled'
ELSE 'Disabled' END AS JOB_ENABLED 
,l.name AS JOB_OWNER 
,j.category_id AS JOB_CATEGORY_ID
,c.name AS JOB_CATEGORY_NAME
,[description] AS JOB_DESCRIPTION 
,date_created AS DATE_CREATED 
,date_modified AS DATE_MODIFIED
FROM msdb.dbo.sysjobs j
INNER JOIN msdb.dbo.syscategories c ON j.category_id = c.category_id
INNER JOIN sys.syslogins l ON l.sid = j.owner_sid
WHERE l.name= @login_name
ORDER BY j.name



DECLARE @job_owner NVARCHAR(32);

SET @job_owner='sa';

SELECT 'EXEC msdb.dbo.sp_update_job @job_name=N''' +j.name + ''', @owner_login_name=N''' + RTRIM(LTRIM(@job_owner)) + ''';' AS change_job_owner_cmd
FROM msdb.dbo.sysjobs j
INNER JOIN msdb.dbo.syscategories c ON j.category_id = c.category_id
INNER JOIN sys.syslogins l ON l.sid = j.owner_sid
WHERE l.name = @login_name
ORDER BY j.name


SELECT '
USE [master]
GO
DROP LOGIN ' + QUOTENAME(@login_name) + 
'
GO
' AS drop_login_user;

然后刪除用戶(User),此腳本也可以清理那些登錄名已經刪除,但是對應的USER沒有清理的Windows 認證用戶。此腳本可能有一些邏輯上的Bug,個人也是fix掉了一些Bug后,才發布這篇博客。如果遇到什么Bug,可以留言反饋。

DECLARE @database_id INT;
DECLARE @database_name sysname;
DECLARE @cmdText NVARCHAR(MAX);
DECLARE @prc_text NVARCHAR(MAX);
DECLARE @RowIndex INT;
DECLARE @user_name NVARCHAR(128);


IF OBJECT_ID('TempDB.dbo.#databases') IS NOT NULL
DROP TABLE dbo.#databases;

CREATE TABLE #databases
(
database_id INT,
database_name sysname
)


INSERT INTO #databases
SELECT database_id ,
name
FROM sys.databases
WHERE name NOT IN ( 'master', 'tempdb', 'model', 'msdb',
'distribution', 'ReportServer',
'ReportServerTempDB', 'YourSQLDba' )
AND state = 0; --state_desc=ONLINE 


CREATE TABLE #removed_user
(
username sysname
)

--開始循環每一個用戶數據庫(排除了上面相關數據庫)
WHILE 1= 1
BEGIN


SELECT TOP 1 @database_name= database_name 
FROM #databases
ORDER BY database_id;

IF @@ROWCOUNT =0 
BREAK;


SET @cmdText = 'USE ' + @database_name + ';' +CHAR(10)

SELECT @cmdText += 'INSERT INTO #removed_user
SELECT name FROM sys.sysusers
WHERE sid NOT IN (SELECT sid FROM sys.syslogins WHERE isntname=1 AND name LIKE ''GFG1%'')
AND isntname=1 AND name NOT IN (''NT AUTHORITY\SYSTEM'')' + CHAR(10);

EXEC SP_EXECUTESQL @cmdText

SELECT @database_name AS database_name;

SELECT j.job_id AS JOB_ID 
,j.name AS JOB_NAME 
,CASE WHEN [enabled] =1 THEN 'Enabled'
ELSE 'Disabled' END AS JOB_ENABLED 
,l.name AS JOB_OWNER 
,j.category_id AS JOB_CATEGORY_ID
,c.name AS JOB_CATEGORY_NAME
,[description] AS JOB_DESCRIPTION 
,date_created AS DATE_CREATED 
,date_modified AS DATE_MODIFIED
FROM msdb.dbo.sysjobs j
INNER JOIN msdb.dbo.syscategories c ON j.category_id = c.category_id
INNER JOIN sys.syslogins l ON l.sid = j.owner_sid
INNER JOIN #removed_user r ON l.name = r.username
ORDER BY j.name;


SELECT d.name AS database_name ,
l.name AS database_owner ,
d.create_date AS create_date ,
d.collation_name AS collcation_name ,
d.state_desc AS state_desc
FROM sys.databases d
INNER JOIN sys.syslogins l ON d.owner_sid = l.sid
INNER JOIN #removed_user r ON r.username = l.name


SET @cmdText = 'USE ' + @database_name + ';' +CHAR(10)

SET @cmdText += 'SELECT * FROM sys.schemas s
INNER JOIN #removed_user r ON s.name =r.username Collate Database_Default' + CHAR(10);

EXEC SP_EXECUTESQL @cmdText;


SET @cmdText = 'USE ' + @database_name + ';' +CHAR(10)

SET @cmdText += 'SELECT * FROM sys.objects WHERE schema_id IN (SELECT s.schema_id FROM sys.schemas s INNER JOIN #removed_user r ON s.name =r.username Collate Database_Default);'

EXEC SP_EXECUTESQL @cmdText;

SET @cmdText = 'USE ' + @database_name + ';' +CHAR(10)
SET @cmdText += 'SELECT ''USE ' + @database_name + ';'' + CHAR(10) +''GO'' + CHAR(10) +''ALTER AUTHORIZATION ON SCHEMA::'' +QUOTENAME(s.name) +'' TO [dbo];'' AS change_schema_cmd FROM sys.schemas s
INNER JOIN #removed_user r ON s.name =r.username Collate Database_Default ' + CHAR(10);

EXEC SP_EXECUTESQL @cmdText, N'@database_name sysname',@database_name ;

SET @cmdText = 'USE ' + @database_name + ';' +CHAR(10)
SET @cmdText += 'SELECT ''USE ' + @database_name + ';'' + CHAR(10) +''GO'' + CHAR(10) +''ALTER AUTHORIZATION ON SCHEMA::'' +QUOTENAME(s.SCHEMA_NAME) +'' TO [dbo];'' AS change_schema_cmd
FROM INFORMATION_SCHEMA.SCHEMATA s
INNER JOIN #removed_user r ON s.SCHEMA_OWNER =r.username Collate Database_Default' + CHAR(10);

EXEC SP_EXECUTESQL @cmdText, N'@database_name sysname',@database_name ;

SELECT 'USE ' + QUOTENAME(@database_name) + CHAR(10)
+ 'GO ' + CHAR(10)
+ 'DROP USER ' + QUOTENAME(username) +';' + CHAR(10)
+ 'GO' AS drop_user_cmd
FROM #removed_user;


TRUNCATE TABLE #removed_user;


DELETE FROM #databases WHERE database_name=@database_name;

END

DROP TABLE #databases;
DROP TABLE #removed_user;

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • SQL Server中identity(自增)的用法詳解
  • Sql Server中清空所有數據表中的記錄
  • SQL server 自增ID--序號自動增加的字段操作
  • SQL Server重置IDENTITY屬性種子值操作

標簽:防疫戰設 宿州 天水 來賓 威海 七臺河 銅仁 益陽

巨人網絡通訊聲明:本文標題《SQL Server正確刪除Windows認證用戶的方法》,本文關鍵詞  SQL,Server,正確,刪除,Windows,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server正確刪除Windows認證用戶的方法》相關的同類信息!
  • 本頁收集關于SQL Server正確刪除Windows認證用戶的方法的相關信息資訊供網民參考!
  • 推薦文章
    a级精品九九九大片免费看| 亚飞与亚基在线观看| 999久久狠狠免费精品| 国产不卡福利| 国产麻豆精品高清在线播放| 国产国语在线播放视频| 国产高清在线精品一区二区| 亚洲爆爽| 久草免费资源| 国产国语对白一级毛片| 国产一区二区精品在线观看| 日韩一级黄色大片| 国产亚洲精品成人a在线| 国产视频一区二区三区四区| 99热精品在线| 成人免费网站视频ww| 日本乱中文字幕系列| 国产不卡高清| 青青久久精品| 日韩专区亚洲综合久久| 国产91精品露脸国语对白| 九九精品在线播放| 成人av在线播放| 国产不卡高清| 国产国语在线播放视频| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品视频免费观看| 91麻豆国产| 欧美激情在线精品video| 日本在线不卡免费视频一区| 香蕉视频久久| 香蕉视频久久| 一级毛片视频播放| 在线观看成人网| 日韩在线观看视频免费| 成人免费观看网欧美片| 91麻豆精品国产自产在线观看一区 | 欧美爱色| 日韩专区一区| 毛片的网站| 欧美国产日韩在线| 国产麻豆精品免费视频| 一级女性全黄生活片免费| 国产一区二区精品久久91| 久久成人综合网| 免费国产在线观看| 免费国产在线观看不卡| 国产精品免费久久| 成人影院一区二区三区| 欧美18性精品| 久久精品店| 在线观看成人网| 在线观看成人网| 美国一区二区三区| 国产成人女人在线视频观看| 日韩av成人| 精品久久久久久中文字幕一区| 亚洲第一页色| 日韩中文字幕一区| 国产原创中文字幕| 欧美18性精品| 日本伦理黄色大片在线观看网站| 韩国三级视频网站| 国产亚洲精品成人a在线| 人人干人人插| 亚洲精品影院久久久久久| 亚州视频一区二区| 免费毛片播放| 99久久精品国产麻豆| 久久精品欧美一区二区| 日本免费看视频| 麻豆系列 在线视频| 91麻豆国产福利精品| 可以免费看污视频的网站| 韩国三级香港三级日本三级| 一级女性大黄生活片免费| 夜夜操网| 中文字幕97| 欧美一区二区三区性| 日韩在线观看免费完整版视频| 在线观看成人网| 欧美α片无限看在线观看免费| 四虎影视久久久免费| 999久久狠狠免费精品| 精品国产一区二区三区久| 韩国三级视频在线观看| 国产网站免费观看| 欧美另类videosbestsex高清| 九九九国产| 欧美激情在线精品video| 韩国毛片 免费| 欧美国产日韩在线| 亚洲爆爽| 国产a一级| 美国一区二区三区| 国产成人精品一区二区视频| 日本乱中文字幕系列| 韩国三级一区| 国产精品免费久久| 欧美国产日韩在线| 精品国产香蕉在线播出| 亚洲女人国产香蕉久久精品| 麻豆午夜视频| 日韩一级黄色| 欧美大片一区| a级毛片免费观看网站| 九九热精品免费观看| 天堂网中文在线| 欧美另类videosbestsex视频 | 日日夜夜婷婷| 精品视频一区二区三区免费| 精品国产三级a| 四虎久久影院| 国产麻豆精品视频| 美女免费精品高清毛片在线视| 麻豆午夜视频| 久草免费在线视频| 91麻豆tv| 精品视频在线观看一区二区三区| 日韩一级黄色| 精品在线观看国产| 99色视频| 色综合久久手机在线| 午夜激情视频在线播放| 精品国产一区二区三区国产馆| 91麻豆国产| 国产不卡高清| 成人影视在线播放| 91麻豆精品国产自产在线| 国产麻豆精品| 日日日夜夜操| 久草免费在线观看| 国产网站麻豆精品视频| 国产91丝袜在线播放0| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产精品12| 久久久成人网| 欧美一区二区三区在线观看| 久久99这里只有精品国产| 成人免费高清视频| 天天色成人网| 沈樵在线观看福利| 黄色免费三级| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久精品国产国产毛片| 久久成人性色生活片| 成人免费观看视频| 国产一区二区精品久久91| 中文字幕一区二区三区 精品| 成人高清免费| 一级毛片视频在线观看| 超级乱淫伦动漫| 亚洲精品影院一区二区| 久草免费在线视频| 日本免费乱人伦在线观看 | 夜夜操网| 国产成人精品影视| 尤物视频网站在线观看| 欧美激情一区二区三区视频 | 国产a一级| 精品国产一级毛片| 九九久久99| 亚飞与亚基在线观看| 久久精品店| 一级毛片视频免费| 999久久66久6只有精品| 国产一区免费在线观看| 深夜做爰性大片中文| 天天色色网| 黄视频网站免费| 黄视频网站在线免费观看| 国产国产人免费视频成69堂| 免费的黄色小视频| 超级乱淫伦动漫| 亚洲精品永久一区| 免费一级生活片| 成人免费观看网欧美片| 二级特黄绝大片免费视频大片| 日本特黄特黄aaaaa大片| 精品国产一区二区三区免费| 亚洲精品中文字幕久久久久久| 国产麻豆精品| 久久国产一久久高清| 黄视频网站免费看| 91麻豆精品国产片在线观看| 亚洲天堂一区二区三区四区| 夜夜操网| 91麻豆精品国产自产在线| 欧美α片无限看在线观看免费| 国产一区免费在线观看| 欧美a级成人淫片免费看| 九九热精品免费观看| 国产不卡精品一区二区三区| 中文字幕一区二区三区 精品| 黄色福利片| 香蕉视频亚洲一级| 台湾美女古装一级毛片| 色综合久久天天综合观看| 国产精品1024在线永久免费 | 免费毛片播放|