方法一:
sp_password Null,'123,'sa'
把sa的密碼設為“123”
執行成功後有“Command(s) completed successfully.” OK!
方法二:
第一步:打開 SQL2008 用管理員登錄先,然後在服務名處右擊選屬性>安全性>右邊的登錄方式選項改為身份驗證 確定!
第二步:選擇安全性(展開)>登錄名>雙擊sa>密碼改成你需要的密碼確定!
然後關掉SQL2008 或者 斷開連接
第三步:點開始>程序>選擇SQL2008>配置工具>打開 configuration manager>展開 SQL Server2005 網絡配置
注意:選中MSSQLSERVER 如果沒有 選中SQMEXPRESS
>TCP/IP 選項 >先啟用 然後右鍵單擊 > 屬性 > Ip地址選項卡 > 把已禁用的選項全部改成已啟用 > 然後把SQL2008 的服務重新啟動一下!
情況二:忘記了密碼,而且從sysadmin中刪除了builtin\Administrators帳號,現在沒其他人是sysadmin了
A:
SQL
Server
2005/2008提供了針對該情況的更好的災難恢復方法,無需侵入master數據庫,不會對master數據庫中的對象和數據(例如登陸帳號,證書
等)造成損壞。Windows管理員組的成員現在當SQL Server以單用戶模式啟動(另外一個名稱為維護模式)的情況下對SQL
Server有了訪問權限。
通過使用單用戶模式,SQL Server 2005/2008避免了Windows管理員以sysadmin的身份在不被發現的情況下濫用權限。Windows管理員帳號能進行部分維護任務,例如安裝補丁等。
要將SQL Server以單用戶模式啟動,您可以在命令行模式下增加“-m”參數。您也可以使用SQL Server配置管理員工具。它提供了對文件訪問和其他權限的合適控制。要是用配置管理工具來恢復您的系統,您可以根據如下步驟:
1. 從菜單->SQL Server 2005->配置,打開配置管理工具(SQL Server Configuration Manager)
2. 停止您想要恢復的SQL Server實例
3. 找到“高級”標簽,“啟動參數”選項文本框中增加“;–m”
4. 點擊“是”按鈕,重新啟動SQL Server實例
請注意:請確保在“;”和“-m”之間沒有空格。注冊參數解析器對類似的輸入錯誤非常敏感。您可以在SQL Server的ERRORLOG文件內看到顯示“SQL Server started in single-user mode.”
5.
在SQL Server實例以單用戶模式啟動後,Windows管理員帳號就能使用sqlcmd工具在Windows驗證模式下連接SQL
Server。您可以使用T-SQL命令諸如“sp_addsrvrolemember”來在sysadmin服務器角色中添加現有登錄帳號或新創建一個
登錄帳號。范例語句如下:
EXEC sp_addsrvrolemember 'CONTOSO\Buck', 'sysadmin';
GO
6. 只要sysadmin訪問權限被恢復,在配置管理中從啟動參數中移除“;-m”參數,重新啟動SQL Server實例
重要的安全提示:
a. 該過程應該只能被用於當沒有其他方法使用特權帳號(例如sysadmin或等同角色)來訪問系統的災難恢復。
b. 該過程允許Windows管理員在SQL Server中有越權行為。它包含了可以被監測和檢測出的明確的侵入行為,包含:
1. 在單用戶模式下停止SQL Server並重啟
2. 使用Windows帳號連接SQL Server