您的位置:首页 > 其它

由于执行触发器,登录名 'sa' 的登录失败

2020-02-03 04:33 676 查看

使用触发器限制数据库连接IP

如:

USE master GO

if exists (select * from sysobjects where name = 'tr_LoginCheck' and type='TR')

drop trigger dbo.tr_LoginCheck

GO

CREATE TRIGGER tr_LoginCheck ON ALL SERVER

FOR LOGON AS IF EVENTDATA().value('(/EVENT_INSTANCE/ClientHost)[1]', 'varchar(15)') <> '192.168.1.27'   

ROLLBACK TRAN

GO

结果只有 192.168.1.27能够登陆SQL

本地都无法登陆  研究半天找到解决方案:
使用DAC登陆执行删除触发器语句

1、进入DOS 执行  sqlcmd -A -S localhost    //服务器名  当前示例是本机

2、执行删除触发器语句  DROP TRIGGER tr_LoginCheck ON ALL SERVER

3、输入GO 

4、 OK  (有可能结果提示执行失败,但是实际已经删除触发器了  可以试试)

 

转载于:https://www.cnblogs.com/Mander/p/3913563.html

  • 点赞
  • 收藏
  • 分享
  • 文章举报
baibi1772 发布了0 篇原创文章 · 获赞 0 · 访问量 102 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐