SQLSERVER数据库SA用户密码被改,不能登陆数据库的解决办法

博客介绍了以Windows身份验证登录“查询分析器”,并通过运行存储过程sp_password修改SQL Server中“sa”帐号密码的方法。同时详细说明了sp_password的语法、参数、返回代码值、注释、权限等信息,还给出了更改登录密码的示例。

1.以Windows身份验证登录"查询分析器":
2.运行存储过程修改"sa"帐号密码

sp_password Null,'ok','sa'
运行后sa的密码变为"ok"

 

以下是SQLSERVER帮助中的说明:

sp_password

添加或更改 Microsoft® SQL Server™ 登录的密码。

语法

sp_password [ [ @old = ] 'old_password' , ]
    { [ @new =] 'new_password' }
    [ , [ @loginame = ] 'login' ]

参数

[@old =] 'old_password'

是旧密码。old_passwordsysname 类型,其默认值为 NULL。

[@new =] 'new_password'

是新密码。new_passwordsysname 类型,无默认值。如果没有使用命名参数,就必须指定 old_password

[@loginame =] 'login'

是受密码更改影响的登录名。loginsysname 类型,其默认值为 NULL。login 必须已经存在,并且只能由 sysadmin 固定服务器角色的成员指定。

返回代码值

0(成功)或 1(失败)

注释

SQL Server 密码可包含 1 到 128 个字符,其中可包括任何字母、符号和数字。

新密码以加密的形式更新和存储,因此,任何用户(甚至系统管理员)都不能查看密码。

sysadminsecurityadmin 固定服务器角色的成员使用带全部三个参数的 sp_password 重新设置他们自己的密码时,审核记录反映的却是他们正在更改别人的密码。

sp_password 不能用于 Microsoft Windows NT® 安全帐户。通过 Windows NT 网络帐户连接到 SQL Server 的用户是由 Windows NT 授权的,因此其密码只能在 Windows NT 中更改。

sp_password 不能在用户定义的事务中执行。

权限

执行权限默认地授予 public 角色,以供用户更改自己的登录密码。只有 sysadmin 角色的成员可更改其他用户的登录密码。

示例
A.无原密码的情况下更改登录密码

下面的示例将登录 Victoria 的密码更改为 ok。

EXEC sp_password NULL, 'ok', 'Victoria'
B.更改密码

下面的示例将登录 Victoria 的密码由 ok 改为 coffee。

EXEC sp_password 'ok', 'coffee'
要修 SQL Server 数据库中的 `sa` 账户密码,可以通过多种方式实现,具体取决于使用的 SQL Server 版本和操作系统。以下是几种常见方法: ### 使用 SQL Server Management Studio (SSMS) 修 SA 密码 1. 打开 SQL Server Management Studio 并连接到目标 SQL Server 实例。 2. 在“对象资源管理器”中展开“安全性”节点,然后展开“登录名”。 3. 右键点击 `sa` 登录名,选择“属性”。 4. 在“常规”页面中,输入新的密码并确认。 5. 单击“确定”保存更。 此方法适用于 SQL Server 的图形界面管理工具,适合大多数用户操作。 ### 使用 Transact-SQL SA 密码 如果更倾向于使用命令行,可以使用 `ALTER LOGIN` 语句来修 `sa` 密码。以下是示例代码: ```sql ALTER LOGIN sa WITH PASSWORD = 'NewPassword123!'; ``` 执行此语句后,`sa` 账户的密码将被更新为 `NewPassword123!`。请确保新密码符合 SQL Server 的复杂性要求。 ### 在 Linux 上使用环境变量配置 SA 密码 如果是在 Linux 上运行 SQL Server,并且需要通过命令行进行无提示安装或配置,可以使用环境变量来设置 `sa` 密码。例如: ```bash sudo ACCEPT_EULA=Y MSSQL_SA_PASSWORD='NewPassword123!' /opt/mssql/bin/mssql-conf setup ``` 此命令在安装过程中接受 EULA (`ACCEPT_EULA=Y`),并设置 `sa` 用户密码 (`MSSQL_SA_PASSWORD`)。这种方式特别适用于自动化部署场景[^3]。 ### 注意事项 - 确保 `sa` 密码足够复杂,以提高数据库安全性。 - 如果 SQL Server 处于混合身份验证模式,则可以使用 `sa` 账户进行身份验证[^4]。 - 修 `sa` 密码后,所有依赖于旧密码的应用程序或脚本都需要更新为新密码。 通过以上方法,可以有效地修 SQL Server 数据库中的 `sa` 账户密码。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值