设为首页 收藏本站
查看: 918|回复: 0

[经验分享] SQL Server 查询Active Directory

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-2-1 09:28:15 | 显示全部楼层 |阅读模式
最近在研究将AD的数据如何快速筛选、查找、比较、分析。在AD里并不好操作,希望导入到SQL Server做统一查询,并且可以和其他系统WSUS、SCCM、SCOM、HR等关联。

1. 创建SQL连接器:
    建立Linked Server:   
1
2
3
EXEC sp_addlinkedserver 'ADSI', 'Active Directory Services 2.5',
'ADSDSOObject', 'adsdatasource'
GO



2. 添加权限:
    因为查询的LDAP,需要用AD域账户进行认证
QQ截图20160201092809.png

3.  通过SQL 语句查询AD信息:

1
2
3
4
5
6
    SELECT  * FROM OPENQUERY
(
ADSI,'SELECT cn
FROM ''LDAP://ServerName/DC=Contoso,DC=domain''
where objectClass = ''computer''
')



4. 创建查询视图

1
2
3
4
5
6
7
8
9
10
CREATE VIEW viewADContacts
AS
SELECT *
FROM OPENQUERY( ADSI,
   'SELECT Name, SN, ST,CN
   FROM ''LDAP://ServerName/DC=Contoso,DC=Domain''
   WHERE objectCategory = ''Person'' AND
      objectClass = ''user'' ')
GO
SELECT * FROM viewADContacts



PS:
    因为LDAP限制返回的信息行数只有1000,当你的域信息大于1000时会非常麻烦。接下来分享如何通过NTDSUtil来修改默认值。
    前提是你是域管理员,修改有风险,前请三思。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# Run as  Administrator进入命令行模式执行NTDSUTIL.exe
PS C:\Windows\system32> ntdsutil

# 输入LDAP Policies,进入LDAP策略设置模式
# 如果不知道如何输入,可以用?或help 查询帮忙
C:\Windows\system32\ntdsutil.exe: LDAP policies

# 设置连接服务器
ldap policy: connections

# 可以连接服务器,也可以连接域名
server connections: connect to domain Contoso.Domain
Binding to  ...
Connected to  credentials of locally logged on user.server

# 输入quit返回上一层
server connections: quit

# 使用Show values显示目前的设定值
ldap policy: show values
Policy                          Current(New)
MaxPoolThreads                  4
MaxDatagramRecv                 4096
MaxReceiveBuffer                10485760
InitRecvTimeout                 120
MaxConnections                  5000
MaxConnIdleTime                 900
MaxPageSize                     5000
MaxQueryDuration                120
MaxTempTableSize                10000
MaxResultSetSize                262144
MinResultSets                   0
MaxResultSetsPerConn            0
MaxNotificationPerConn          5
MaxValRange                     1500

# 使用set 修改MaxPageSize就是我们要扩充的对象
ldap policy: set MaxPageSize to 5000

# 使用commit changes提交变更
ldap policy: commit changes

# 修改完成quit返回退出
ldap policy: quit

C:\Windows\system32\ntdsutil.exe: quit

PS C:\Windows\system32>



    再用SQL查询看看,不会再报错,也不会有1000条的限制啦。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-172139-1-1.html 上篇帖子: SQLServer数据库如何收缩日志空间? 下篇帖子: 将MSSQL表数据转成SQL语句
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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