こんにちはゲストさん。会員登録(無料)して質問・回答してみよう!

解決済みの質問

SQLサーバーへの接続に 接続したいのですが・・・

質問する場所が 違ったかもしれないので 再度質問させていただきます。
SQLサーバーを始めたばかり です。
ASPで SQLサーバーのデータを表示しようとしています。
環境: WinXP (Pro)
    IIS設定済み
    SQL Server 2005 Express Edition

近くに2003サーバーがあるので 最終的にはそちらで動作させる予定です。
サーバーが現用機なので 自PCで動作確認してからと思っています。

色々ネットや本を調べて まず接続しようとしましたが そこでつまづいています。
この方法以外も沢山試しましたが全てうまく行きません。

2005 ExpressでDBとテスト用のテーブルが作成してあります。
そのデータを読み出せれば 第一段階とトライしますが、
IEから接続にいくと「objCon.Open」がエラーになってしまいます。
ASPファイルの内容は 以下です
なお DB名は 「作成した名前」と入れています
よろしく お願いします
----------------------------------------------------
<%@ LANGUAGE="VBScript" %>
<% option explicit %>
<%
Dim objCon ' DB接続コネクション
Dim objRS ' DB結果レコードセット
Dim sql ' SQL文
Dim errflg ' エラーフラグ
'DataSource名
Const DS = "111.111.0.1" ←IPアドレス。正しいものをいれてます
Const IC = "DB名"     
'ユーザ名
Const User = "sa"
'パスワード
Const Pwd = "sa"
Set objCon = Server.CreateObject("ADODB.Connection")
Set objRS = Server.CreateObject("ADODB.Recordset")
objCon.ConnectionString = "Provider=SQLOLEDB;" & _
"User ID=" & User & ";" & _
"Password=" & Pwd & ";" & _
"Data Source=" & DS & ";" & _
"Initial Catalog=" & IC
objCon.Open'ここで エラーになります

sql = "select * from Aテーブル"
objRS.Open sql,objCon,adOpenStatic,adLockReadOnly
%>
レコード件数 <%=objRS.RecordCount%>
<%
' DBclose
objCon.Close()
Set objCon = Nothing
objRS.Close()
Set objRS = Nothing
%>
なお エラー内容は 以下です
-----------------------------
HTTP 500.100 - 内部サーバー エラー - ASP エラー
インターネット インフォメーション サービス
エラー タイプ
Microsoft OLE DB Provider for SQL Server (0x80004005)
[DBNETLIB][ConnectionOpen (Invalid Instance()).]接続が正しくありません
-----------------------------
また 
1.IPアドレスは Const DS = "127.0.0.1"でも 同様なエラーです
2.表示できるASPファイルを置き、他のPCから 表示できる環境です

投稿日時 - 2010-02-08 07:19:28

QNo.5658397

すぐに回答ほしいです

質問者が選んだベストアンサー

>それとも saで Server認証が接続できないとダメでしょうか?

ご提示されているコーディングからすると、
Management Studio を起動して SQL Server 認証を選び、ユーザID・パスワード共に sa でログインできる筈です。それができないのであれば、ASP からもつながりません。
SQL Server 認証を利用できるようにし、かつ sa アカウントを有効にする必要があります。

>調べた限りでは saは パスワード無しで セットされていると思うのです。

であれば、コーディング上もパスワード無しではないでしょうか。
今はパスワードも sa を設定されているようですが。。。

投稿日時 - 2010-02-17 20:41:08

補足

回答ありがとう ございます。所用により やっと今確認しました。
スミマセン。

>ご提示されているコーディングからすると、
>Management Studio を起動して SQL Server 認証を選び、ユーザID・パスワード共に
> sa でログインできる筈です。それができないのであれば、ASP からもつながりません。
>SQL Server 認証を利用できるようにし、かつ sa アカウントを有効にする必要があります。

調べてみましたら saアカウントは 有効でした。
アカウント:sa パスワード:xxxxxxx  で 接続できました

ASPファイルを そのように変更しても 同様なエラーです。
なにか根本的な 勘違いがあるのでしょうか?

投稿日時 - 2010-02-18 17:14:08

ANo.6

このQ&Aは役に立ちましたか?

5人が「このQ&Aが役に立った」と投票しています

回答(6)

ANo.5

もしかして Management Studio で sa で接続できないとか、そんな事はないですよね?
もしもそうであれば、SQL Server 認証との混在モードに設定し、SQL Server の再起動を行う必要があります。
http://msdn.microsoft.com/ja-jp/library/ms188670.aspx

ご参考になれば良いのですが。。。頑張ってください。

投稿日時 - 2010-02-15 17:30:10

お礼

回答ありがとう ございます
出張で お礼が遅れました。スミマセン。
Management Studio Express では Windows統合認証で接続できます。
ご指摘のURLにて 調べましたが どうも設定は良いような?気がする
のですが・・・。
それとも saで Server認証が接続できないとダメでしょうか?

調べた限りでは saは パスワード無しで セットされていると思うのです。
SQL サーバでこんな部分で 詰まるとは思っていなくて そこらへんが 
イマイチ解らなくて 困ってます。

投稿日時 - 2010-02-17 19:05:22

ANo.4

データソースを 「.\SQLEXPRESS」 としてみるとどうなりますか?

この辺とかが参考になるかもしれません。
http://www.ailight.jp/blog/ishino/archive/2005/11/17/10102.aspx
http://www.accessclub.jp/bbs6/0023/das7021.html

投稿日時 - 2010-02-14 21:36:20

お礼

回答ありがとうございます
>データソースを 「.\SQLEXPRESS」 としてみるとどうなりますか?

この方法とご指摘の参考HPを試しましたが ウマくいかないようです。

なお Management Studio Expressでは サーバー認証は「Windows認証」で
「PC名\SQLEXPRESS」を使用して DBにアクセスできます

またフリーソフトの 「quickDBExplorer」では サーバー名だけを指定して
インスタンスは空白のWindows認証で 接続でき、テスト用テーブル内容を
確認できます

投稿日時 - 2010-02-15 10:12:32

ANo.3

いくつか質問させてください。
IISは設定済みとなっていますが、1.「仮想ディレクトリのアクセス許可でASP等のスクリプトの実行する」にチェックが入っていますか?
2.ディレクトリセキュリティの設定で「匿名アクセス」にチェックが要っていますか?
上記2点が気になりましたので教えてください。

参考URL:http://www.apec.aichi-c.ed.jp/project/joho/kanri/win2000/IIS.htm

投稿日時 - 2010-02-13 23:51:15

お礼

回答ありがとうございます

>1.「仮想ディレクトリのアクセス許可でASP等のスクリプトの実行する」
>にチェックが入っていますか?

スクリプトソースアクセスを有効にしましたが 同様でした

>2.ディレクトリセキュリティの設定で「匿名アクセス」にチェックが要っていますか?

 ここは触っていないのですが 匿名アクセス が有効で ユーザ名とパスワードは
 不要と表示されています
 
 
また ASPファイルに 表示などの簡単なテストを作成して 他PCからアクセスすると
問題なく 表示できます

投稿日時 - 2010-02-15 10:29:35

ANo.2

Express Edition は動的ポートだったかと。
http://www.atmarkit.co.jp/fdotnet/dotnettips/545sqlsvrnet/sqlsvrnet.html

投稿日時 - 2010-02-10 12:40:35

お礼

回答ありがとうございます。
Express Edition に動的ポート(1433)を強制設定したり
SQL Server Browserサービスを有効に
しましたが エラー内容は変化しません。
どこかの設定なんでしょうか?

投稿日時 - 2010-02-10 13:57:56

ANo.1

SQL Server のネットワーク接続は有効になってますかね。
http://www.google.com/search?hl=ja&num=50&q=SQL+Server+express+ip%E3%82%A2%E3%83%89%E3%83%AC%E3%82%B9+%E6%8E%A5%E7%B6%9A&lr=lang_ja&aq=f&oq=

投稿日時 - 2010-02-09 23:15:48

お礼

回答ありがとうございます。
SQL Serverは TCP/IPで ポート1433をセットしていましたが これは
Express Edition 以外の事だったんでしょうか?
IPALLの項目で 1433を設定していますが 動的ポートのセットが
必要なのでしょうか?

投稿日時 - 2010-02-10 00:05:38

あなたにオススメの質問