ASPにてODBC経由でオラクルにADOで接続してデータを表示していますが、GROUP BY 区を追加すると「オブジェクトが閉じている場合は、操作は許可されません」とエラーが発生します。
GROUP BY 区を追加しなければエラーが発生しません。どうしてでしょうか?またこの接続方法の場合JetのSQL関数が使用可能でしょうか?
ASPの中身--------------------------------------
cn = Server.CreateObject("ADODB.Connection");
rs = Server.CreateObject("ADODB.Recordset");
cn.Open("DSN=XXXXX;UID=XXXXX;PWD=XXXXX;");
sq="";
sq+="SELECT ";
sq+="TTUMIAGK.BUCD ";
sq+="FROM ";
sq+="TTUMIAGK ";
sq+="WHERE ";
sq+="TTUMIAGK.BUCD='04' ";
sq+="GROUP BY TTUMIAGK.BUCD;";//追加するとエラー
rs.Open(sq, cn ,3);
while (!rs.eof) { //ここでエラーが発生
j++;
%><tr><%
for (i=0;i<rs.Fields.count;i++){
%><td><%=rs(i).value%></td><%
}
%></tr><%
rs.movenext();
}
rs.close();
No.3ベストアンサー
- 回答日時:
ANo.1,2です。
すみません、難しく考えすぎでした。
sq+="GROUP BY TTUMIAGK.BUCD;";//追加するとエラー
の"TTUMIAGK.BUCD"の後ろの";"が不要なんですね(^^;
この回答への補足
ありがとうございました。単純なミスでした。
ACCESSのSQLは分かるのですがオラクルは
難しいですね。
SELECT
TTUMIAGK.BUCD
FROM
TTUMIAGK
GROUP BY
TTUMIAGK.BUCD
「オブジェクトが閉じている場合は、操作は許可されません。」とエラーが出てしまいますが
SUM(TTUMIAGK.YTKIN) を追加するエラーがでませんでした。しかも「SELECT TTUMIAGK.BUCD」の部分が表示されずSUM関数の結果のみ表示されました。う~んオラクルはやっぱり難しいです。
No.2
- 回答日時:
ANo.1です。
ご指摘の通り、グループ化関数とはSUM関数やCOUNT関数などのことです。
GROUP BY部に指定していないカラムについてもSELECT部に記述していませんか?そうするとSQL文が正しくなく、実はrs.Open()でエラーとなっており、rsオブジェクトが利用可能になっておらず、rs.eofで今回のエラーが表面化するのだと思います。
No.1
- 回答日時:
SQLについてですが、これは検索後'04'しか帰ってこないのですがこれをグループ化する必要があるのでしょうか・・・?
実際には、他のカラムについて取得しているようならグループ関数を利用しているかがエラーの発生原因として浮上してきますのでご確認を。
次に、Jetの関数というのはSQLの中で利用する関数のことでしょうか?
もしそうであればJetの関数をOracleでは利用できません。同様の機能を持つOracleの関数を利用してください。
この回答への補足
すみませんWHERE文は必要ありませんでした。
「グループ関数を利用しているかが」が分かりません。
SUM関数などのことでしょうか?
Jetの関数はSQLの中で使用する関数(SUM関数)などです。
説明不足でした。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C# try-catch でcatchに飛ばす方法
-
EXECLマクロでshapeがグルーフ...
-
fopenでエラーとなる
-
自作PCにWindowsXPのインストー...
-
FileCopy時のエラー
-
C++でSQLServer2008に接続
-
実行時エラー '-2147024726
-
エラー内容について
-
VB6+SQLServer2005 DBの新規作成
-
「a.v.v」「iiMK」の...
-
Panelを重ねる方法
-
エクセルVBA 宣言Dimの場所
-
名前が二重に定義されています
-
Tableを動的に増やしたい。
-
【ASP.NET】 ログインコントロ...
-
VBSにてサーバー中のエクセルフ...
-
Buttonの処理について
-
ソケット通信で同時受信の制限?
-
画面のリフレッシュを意図的に...
-
ASPからASPを呼び出す方法
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C# try-catch でcatchに飛ばす方法
-
FileCopy時のエラー
-
CreateObject("Excel.Applicati...
-
Outlookで添付ファイルの有無を...
-
fopenでエラーとなる
-
VBSからPDFファイルを開きたい...
-
このページの状態情報は無効で...
-
エラー 'ASP 0115' について
-
VB6でRDOに接続できない
-
EXECLマクロでshapeがグルーフ...
-
winsock通信時エラーの回避
-
VBA RemoveDuplicatesで「アプ...
-
ASP 0x80004005 クライアント...
-
ASP.NETで使用しているJavascri...
-
【C#】アップロード時に「アプ...
-
VBAでIE操作ができない ...
-
ASPプログラミングでADODB.C...
-
ジェネリックなメソッドでDirec...
-
型が一致しません
-
オラクル接続をopenしようとす...
おすすめ情報