アプリ版:「スタンプのみでお礼する」機能のリリースについて

PostgreSQLの初心者です。よろしくお願いします。
今、日本語ODBCドライバを使ってクライアント側を
VB.NETでプログラムを作っています。PostgreSQLは8.1.4です。
レコードの追加をするために、レコードIDのMAX値を
撮るためにプログラム中にSQL
sql = "SELECT MAX(user_id) AS MaxID FROM user"
を入れて発行したところ、本来ですと「1」が返って
こなければいけないのに、
Msgbox(MaxID)
を仕込むと「0」が返ってきます。そして、その後に

ERROR [HY000] Error while executing the query;
ERROR; operator does not exist: # integer

というエラーが返ってきます。

先ほどのSQLはリモートで直接PostgreSQLにつなぐと
ちゃんと「1」が返ってくるのですが、VB.NET上では
うまくいきません。

質問としては2つあります。
1)VB.NET上で実行すると、なぜ「0」が返ってきて
しまうのか?
2)エラーメッセージの意味
の2点です。

よろしくお願いします。

A 回答 (4件)

型が違いませんか?



Int型をString型として使ってる気がします。
    • good
    • 0
この回答へのお礼

salfさん、回答ありがとうございます。

psqlで
# d\ user
と入れると、
Column | Type | Modifiers
---------------+-------------------+-----------
user_id | integer | not null
と返ってきますので、間違いなくintegerで定義して
います。
勿論、VB.NET側はMaxIDをintegerで取り扱っています。
他にお気づきの点はないでしょうか?

お礼日時:2006/07/21 12:54

列:user_id の型を確認してみてください。

この回答への補足

ssm3uさん、回答ありがとうございます。

psqlで
# d\ user
と入れると、
Column | Type | Modifiers
---------------+-------------------+-----------
user_id | integer | not null
と返ってきますので、間違いなくintegerで定義して
います。
勿論、VB.NET側はMaxIDをintegerで取り扱っています。
他にお気づきの点はないでしょうか?

補足日時:2006/07/21 12:38
    • good
    • 0

じゃあ、ほかのSQL文を実行できますか?



「Error while executing the query」
って実行エラーって意味だと思うんで、もしかしたらSQLが実行できてないかもしれません。
    • good
    • 0

テーブル構造および型は問題なくて、


psqlコマンドで実行してちゃんと1が返ってくるようであれば、
次はVB.NETプログラミングの問題かと思ってしまいます。

SQL周りだけでも良いので掲載して頂きたいと思います。
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!