- 在线时间
- 0 小时
- 最后登录
- 2007-9-23
- 注册时间
- 2004-9-10
- 听众数
- 3
- 收听数
- 0
- 能力
- 0 分
- 体力
- 9975 点
- 威望
- 7 点
- 阅读权限
- 150
- 积分
- 4048
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1893
- 主题
- 823
- 精华
- 2
- 分享
- 0
- 好友
- 0

我的地盘我做主
该用户从未签到
|
单击"别名"选项卡,还可以为服务器配置别名。服务器的别名是用来连接的名称,连接参数中的服务器是真正的服务器名称,两者可以相同或不同。如下图中,我们可以使用myserver来代替真正的服务器名称sql2kcn-02,并且使用网络库 Named Pipes。别名的设置与使用HOSTS文件有相似之处。# S* |8 k0 C* f2 P" T8 }/ e& p* p
7 y8 B, z J# f8 i; i
2 @; }/ h+ J q0 k( v通过以上几个方面的检查,错误 1 发生的原因基本上可以被排除。下面我们再详细描述如何来解决错误 2。% j! Y, S$ u2 _) e' ^ Q3 H8 c
9 T$ N3 j' g1 E" o L 当用户尝试在查询分析器里面使用sa来连接SQL Server,或者在企业管理器里面使用sa来新建一个SQL Server注册时,经常会遇到如图 2 所示的错误信息。该错误产生的原因是由于SQL Server使用了"仅 Windows"的身份验证方式,因此用户无法使用SQL Server的登录帐户(如 sa )进行连接。解决方法如下所示:$ |1 J4 P9 d* c0 v! V- P
% b7 k4 G% R# G% h( z- j' F 1、 在服务器端使用企业管理器,并且选择"使用 Windows 身份验证"连接上 SQL Server;
" B6 l2 d; `; Z8 |2 y! a/ j- Y, H, B2 J: R0 v" }
2、 展开"SQL Server组",鼠标右键点击SQL Server服务器的名称,选择"属性",再选择"安全性"选项卡;9 d2 J1 g! z# s& |
) ^) a6 d$ c: M
3、 在"身份验证"下,选择"SQL Server和 Windows "。
. g1 N/ j c6 _1 E0 m, B' T" w* Q9 ?" C6 E4 {
4、 重新启动SQL Server服务。9 V6 F6 ~9 S5 N% ^
! V/ G8 b# N- M# q5 T8 P
在以上解决方法中,如果在第 1 步中使用"使用 Windows 身份验证"连接 SQL Server 失败,那么我们将遇到一个两难的境地:首先,服务器只允许了 Windows 的身份验证;其次,即使使用了 Windows 身份验证仍然无法连接上服务器。这种情形被形象地称之为"自己把自己锁在了门外",因为无论用何种方式,用户均无法使用进行连接。实际上,我们可以通过修改一个注册表键值来将身份验证方式改为 SQL Server 和 Windows 混合验证,步骤如下所示:2 p% T. d1 Q! q0 l
9 w. {; l3 i/ o' e( W! f' b3 i 1、点击"开始"-"运行",输入regedit,回车进入注册表编辑器;
7 R$ r) A8 v- I1 S) x y
1 E: W3 w& o6 O* _0 w& k3 y" A 2、依次展开注册表项,浏览到以下注册表键:% ?! M% f* c3 n8 g) M4 J
, i3 G: S1 P/ x3 G8 m, v/ V[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer]
4 D9 e6 V# A) k, ^' D& K
! C, m5 ]6 f8 m 3、在屏幕右方找到名称"LoginMode",双击编辑双字节值;
0 v5 M- A! O0 H3 R) [ I8 ~& w8 m/ S, k
4、将原值从1改为2,点击"确定"; u Y$ M5 H0 f6 R
" j' T$ B% C7 V4 d9 W 5、关闭注册表编辑器;8 E; H, O* n* O& T9 v
: j! P3 o+ [, _ 6、重新启动SQL Server服务。
2 x5 ~& Z- j6 [% }0 d' E t% o; K- L: t( Y# `
此时,用户可以成功地使用sa在企业管理器中新建SQL Server注册,但是仍然无法使用Windows身份验证模式来连接SQL Server。这是因为在 SQL Server 中有两个缺省的登录帐户:BUILTIN\Administrators 以及 <机器名>\Administrator 被删除。要恢复这两个帐户,可以使用以下的方法:
+ s d9 f) ~! Z1 d; T M+ ^* U% e) h
1、打开企业管理器,展开服务器组,然后展开服务器;2 F+ T% J! L+ H$ O
7 |) _; b$ l6 |3 Y" R# F 2、展开"安全性",右击"登录",然后单击"新建登录";# u+ K# ]% S" N4 R; {
* `# Q! K M5 F6 B/ x/ j 3、在"名称"框中,输入 BUILTIN\Administrators;
$ p% C( y- X3 E5 J% u/ g! y
. r4 n2 U5 U* O K$ V 4、在"服务器角色"选项卡中,选择"System Administrators" ;
& c) l4 @- Z. j; }& l' t1 q/ q& e; y8 T% K( u! Q! @
5、点击"确定"退出;' ~5 G) @( X; f2 s& u- T
3 x& u5 ^5 z0 ]8 q 6、使用同样方法添加 <机器名>\Administrator 登录。
/ t" x( b9 P9 D0 D3 a# m, P" r* L0 X2 t7 q" Q' q3 v
以下注册表键
7 v- s7 W% Q9 ?9 \+ L, M( E3 P4 p2 a4 z# q$ M4 b0 Q0 o
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer\LoginMode }! \% X3 [; j' U% a% u6 X
/ p" D% B( Q4 o6 e 的值决定了SQL Server将采取何种身份验证模式。该值为1,表示使用Windows 身份验证模式;该值为2,表示使用混合模式(Windows 身份验证和 SQL Server 身份验证)。
& t4 j R; Y W& q' ^5 b4 \: o' j. Z
8 a& U" G& @$ x h! a$ h6 ` 看完如何解决前两个错误的方法之后,让我们来看一下如图 3 所示的第三个错误。/ ]- [- I" M% ?6 z4 U
; l4 k; ^% ] H" W n
如果遇到第三个错误,一般而言表示客户端已经找到了这台服务器,并且可以进行连接,不过是由于连接的时间大于允许的时间而导致出错。这种情况一般会发生在当用户在Internet上运行企业管理器来注册另外一台同样在Internet上的服务器,并且是慢速连接时,有可能会导致以上的超时错误。有些情况下,由于局域网的网络问题,也会导致这样的错误。
8 f* c* q/ R) X/ X5 r8 U* v9 N9 ^% m( t+ I: J& x
要解决这样的错误,可以修改客户端的连接超时设置。默认情况下,通过企业管理器注册另外一台SQL Server的超时设置是 4 秒,而查询分析器是 15 秒(这也是为什么在企业管理器里发生错误的可能性比较大的原因)。具体步骤为:0 D+ W. N4 p! l. c
o9 Y T) ~- v. s+ W
1、在企业管理器中,选择菜单上的"工具",再选择"选项";5 ^0 m" x6 C8 S! \( _+ C! D7 ~; \
2 }1 b8 U0 M6 J2 ]: d3 P8 `0 G 2、在弹出的"SQL Server企业管理器属性"窗口中,点击"高级"选项卡;
, ^& n9 ~# V4 v ~0 n# _# s+ i& B
0 C% c+ A8 q" C( n/ M 3、在"连接设置"下的"登录超时(秒)"右边的框中输入一个比较大的数字,如 20。
( a V& l" q, j. m$ y3 ?* v# D8 y5 F
) A; C. _0 C1 S( m 查询分析器中也可以在同样位置进行设置。 < >
3 ~$ l! X$ c7 B* X二、应用程序连接失败+ Q. ^6 V/ R. E" e" ]$ l
. u0 H3 P( B& v8 ~0 l+ B' Y* i5 X 以上的三种错误信息都是发生在 SQL Server 自带的客户端工具中,在应用程序中我们也会遇到类似的错误信息,例如:
6 k% b2 w3 _9 ]" ~3 Y; p
% V- f0 D" U' k! D3 E- }3 gMicrosoft OLE DB Provider for SQL Server (0x80004005)
& Z3 B/ l* I$ O" X; D+ C2 Z( w" W[DBNETLIB][ConnectionOpen (Connect()).]Specified SQL server not found.: e- M. ~, e; N. R
8 J& d* W( |4 p$ b' Z6 nMicrosoft OLE DB Provider for SQL Server (0x80004005) u2 d) U) ?/ s. u
用户 'sa' 登录失败。原因: 未与信任 SQL Server 连接相关联。+ O" P# w5 L% e9 u3 v/ B$ q0 B3 u
, ~$ \5 U1 T5 H) L' PMicrosoft OLE DB Provider for ODBC Drivers 错误 '80004005'.& ?8 o& R- y& l8 t" L% e+ [0 C4 t
[Microsoft][ODBC SQL Server Driver]超时已过期.
% ~2 s3 w' o; L& a" d, u9 V! e
5 w9 b1 B5 ?0 i! U& b 首先,让我们来详细看以下的示意图来了解一下使用 ODBC 和使用 OLE DB 连接 SQL Server 有什么不同之处。
& Y# V6 I0 x7 c3 H! E
5 S/ e" R1 Q2 R; O r
" [) B# e8 p0 q* s4 \
2 X2 r0 S& M1 @
, H: U: N2 c5 ^4 c. u 从上图中,我们可以看出在实际使用中,应用程序创建和使用各种 ADO 对象,ADO 对象框架调用享用的 OLE DB 提供者。为了访问 SQL Server 数据库,OLE DB 提供了两种不同的方法:用于 SQL Server 的 OLE DB 提供者以及用于 ODBC 的 OLE DB 提供者。这两种不同的方法对应于两种不同的连接字符串,标准的连接字符串写法如下所示:/ V- n6 f8 c. m& Q- J
9 J( b& ~/ L$ C) ]0 q 1、使用用于 SQL Server 的 OLE DB 提供者:, i" }& ?$ u( k9 Z( |- |& T3 B
& {6 R7 g- n/ G) } U% ]
使用 SQL Server 身份验证:
( P4 G0 d$ N9 U( w( J6 {! R9 S$ [2 @ L6 O/ k) P
oConn.Open " rovider=sqloledb;" & _ : N: \' X% E5 ^2 ]. ?
"Data Source=myServerName;" & _* J2 \6 `4 R0 s) H0 l+ S6 f
"Initial Catalog=myDatabaseName;" & _1 W8 A& [: N" o# q
"User Id=myUsername;" & _$ |3 s, F# J0 B& ^
" assword=myPassword"7 M7 _' m0 t" J0 w- f8 b4 s+ f4 b
8 _! p, X* P& |0 ` 使用 Windows 身份验证(信任连接):
. H, j% v" r' J) }
( u1 g" I* H2 [- _7 ZoConn.Open " rovider=sqloledb;" & _! K! ]) z& d0 i1 W( h& T
"Data Source=myServerName;" & _
: k9 r. O" ~- i5 | W% ]7 z% L"Initial Catalog=myDatabaseName;" & _
( O4 n7 |% m2 O: a; A8 H7 f% ]"Integrated Security=SSPI" B2 @$ v w c) k2 [2 x7 @+ I
3 I, @3 l0 r2 R% f 2、使用用于 ODBC 的 OLE DB 提供者(不使用 ODBC 数据源):, F; L' z$ W5 B, B# c% R3 u- M7 i) F
5 [9 K1 C+ {7 _0 H4 m, r; {6 b 使用 SQL Server 身份验证:
. H2 ~: Q! A5 D' D8 ^0 y. D p8 p- h7 u
oConn.Open "Driver={SQL Server};" & _ * B% X; d z- q4 d1 \' g
"Server=MyServerName;" & _
3 s. o' ]7 u: I"Database=myDatabaseName;" & _
2 c+ u5 n! W% m1 e' d"Uid=myUsername;" & _
N6 V/ @5 l5 W9 J" wd=myPassword". e5 @' ~5 e' `& J y( i. K
. ~: s6 m+ g& g J; T8 p3 ^
使用 Windows 身份验证(信任连接):
9 ~6 S- W; ]6 a' l, p+ S- n4 t; \5 l0 I. Y& }1 P' z
oConn.Open "Driver={SQL Server};" & _
2 Q. f0 F, `, Q7 ]"Server=MyServerName;" & _2 B8 F8 r" A$ g+ g6 A
"Database=myDatabaseName;" & _) M' ?8 I0 M& r: a5 v) Z5 X
"Trusted_Connection=yes"
8 ^, z' S8 e( D( t) L P9 L( x. r9 y w! u
3、使用用于 ODBC 的 OLE DB 提供者(使用 ODBC 数据源):" `& [8 f& Z; B3 w; w! z
7 y6 \" t. S" o5 j- `8 v" yoConn.Open "DSN=mySystemDSN;" & _
/ M; [: T# g4 O. O+ `" E4 e"Uid=myUsername;" & _ l: j* I$ l h& h, C( N( L. s7 W; D. {
" wd=myPassword"8 U( x" t& k' q5 ?4 M$ A8 `
( J1 H) m+ _: V# n
如果遇到连接失败的情况,我们只要按照一中所示的方法,结合程序中的连接字符串进行检查,基本都能得到解决。另外,还有以下几个要注意的地方:
: K# @! m' F" J6 q4 F: {$ D n* o2 z9 y7 x) ^$ K: f; m G$ F8 `
1、配置 ODBC 数据源时,点击"客户端"配置选项可以让我们指定连接使用的网络库、端口号等属性,如下图所示:
+ q4 E% W6 k$ r6 [- f3 {5 E) b' G: v( T
" g K, \; L& K) ?) j6 M/ V" J/ z
% {+ I6 C' I& X4 v) ?* r9 g: A0 A% f3 m+ x" _" a7 I
2、如果遇到连接超时的错误,我们可以在程序中修改 Connection 对象的超时设置,再打开该连接。例如:
* C3 H; Q" ~% h, p9 V
+ M7 n; P/ z% U( h</P>< ><%: M) Q6 p$ `7 H, L$ |
Set Conn = Server.CreateObject("ADODB.Connection")$ L. M# H' `" L9 W4 Y
DSNtest="DRIVER={SQL Server};SERVER=ServerName;UID=USER WD=password;DATABASE=mydatabase") x& P$ T0 @& R5 T
Conn. Properties("Connect Timeout") = 15 '以秒为单位
! o( D1 J; v8 f+ f/ GConn.open DSNtest
* F0 V3 ~" J1 U6 ^2 [2 S6 S* C7 S%></P>< >: t9 d6 p- \ k) t( h5 o( |9 |( P5 z
3、如果遇到查询超时的错误,我们可以在程序中修改 Recordset 对象的超时设置,再打开结果集。例如:" l' \ B7 I% @$ n; y
3 ]. P/ X: k$ H$ t
</P>< >Dim cn As New ADODB.Connection
6 M9 G- }: O: b0 e: E! T4 RDim rs As ADODB.Recordset
- g& ^0 Y. |) A. f. . .
( {9 B- H4 M, x9 Z. jcmd1 = txtQuery.Text
! l# A, H9 X* N* w, \) d' }5 sSet rs = New ADODB.Recordset( b" m* h( X9 |1 L
rs.Properties("Command Time Out") = 300: E% {% G. A2 O7 q
'同样以秒为单位,如果设置为 0 表示无限制
3 a9 J7 _; M: Zrs.Open cmd1, cn0 E; L3 }9 n' E6 B+ m
rs.MoveFirst
( Z* l; [; X/ d" s! a. . . </P>< >, l' \/ W' Y6 T0 {
<B>三、小结</B>) F2 h8 N) p ]" |- d8 v9 {3 i
0 z- o/ c* z, O. m# J- Q2 L4 {8 B( j5 L 本文针对大部分用户在使用 SQL Server 过程中常见的连接失败的错误,重点讨论了在使用 SQL Server 客户端工具以及用户开发的应用程序两种情况下,如何诊断并解决连接失败的错误。看过本文以后,相信每一个读者都会对 SQL Server 的连接工作原理、身份验证方式以及应用程序开发等有一个较为全面而深入的连接。本文中所有的测试或者示例均在 Windows 2000 Advanced Server + SQL Server 2000 企业版上通过。</P> |
|