阳光网驿-企业信息化交流平台【DTC零售连锁全渠道解决方案】

 找回密码
 注册

QQ登录

只需一步,快速开始

扫描二维码登录本站

手机号码,快捷登录

老司机
查看: 2559|回复: 2

[推荐] 忘记SQLServer SA密码的解决方法

[复制链接]

该用户从未签到

发表于 2008-3-23 14:42:47 | 显示全部楼层 |阅读模式
我的台式机和本本分别安装了MS SQL Server,方便做测试用,结果时间长了,台式机SQL Server的密码忘记了……
难道……没有办法了吗?——No!
经过一阵子郁闷,终于在百度搜到了方法:

现在你的企业管理器当然是进不去了,但是我们还有查询分析器
验证的时候,选择按照Windows身份验证,就直接进去了……汗!
输入下列命令,执行:
exec sp_password null,'新密码','sa'
好了,现在密码已经改变了,到企业管理器看看 ^_^

下面是我在SQL Server的帮助看到的关于存储过程 sp_password的说明:

sp_password
添加或更改 Microsoft? SQL Server? 登录的密码。

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

参数
[@old =] 'old_password'是旧密码。old_password 为 sysname 类型,其默认值为 NULL。

[@new =] 'new_password'是新密码。new_password 为 sysname 类型,无默认值。如果没有使用命名参数,就必须指定 old_password。

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

返回代码值
0(成功)或 1(失败)

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

新密码以加密的形式更新和存储,因此,任何用户(甚至系统管理员)都不能查看密码。当 sysadmin 或 securityadmin 固定服务器角色的成员使用带全部三个参数的 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'

评分

参与人数 1阳光币 +6 收起 理由
sea_598 + 6 热心帮助奖励

查看全部评分

楼主热帖
启用邀请码注册,提高发帖质量,建设交流社区

该用户从未签到

发表于 2008-5-2 18:37:47 | 显示全部楼层
还有就是如果有两台机器可在别一台上联接登录后进行密码修改。
启用邀请码注册,提高发帖质量,建设交流社区
  • TA的每日心情
    奋斗
    2024-3-28 23:26
  • 签到天数: 712 天

    [LV.9]以坛为家II

    发表于 2008-5-8 17:15:18 | 显示全部楼层
    如此轻易修改sa密码 那sql岂不是很不安全?
    启用邀请码注册,提高发帖质量,建设交流社区
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    快速回复 返回顶部 返回列表