現在MySQLのDBを使いWeb上で情報を検索できる物を作っています。外の時に県名を入れてもらいその県名に当てはまる物を抽出するというものをやりたいのですが、どうしてもDBの所で止まってしまいます。
どうかおしえていただけないでしょう?下記参照

--参照--
my $num;
my $str1SQL;


$str1SQL=qq{SELECT kyu16 };
$str1SQL=$str1SQL.qq{FROM kyu_table };


if($ADDR1 eq "茨城県"){
# 場所(県)
$STRSQL=$str1SQL;
$STRSQL=$STRSQL.qq{WHERE kyu16 LIKE "%$ADDR1%" };
}


if ($DEBUG_FLG eq '1') {print "STRSQL=$STRSQL<BR>\n";}# debug
$sth = $Com::db->prepare($STRSQL)
or &Com::ErrorDB("<BR><FONT COLOR=\"#FF0000\" SIZE=+1><B>エラーコード:検索04<br>$ERRDBMSG</B></FONT><BR>");
$sth->execute
or &Com::ErrorDB("<BR><FONT COLOR=\"#FF0000\" SIZE=+1><B>エラーコード:検索05<br>$ERRDBMSG</B></FONT><BR>");
$num = $sth->rows;
if ($DEBUG_FLG eq '1') {print "num=$num<BR>\n";}# debug

このQ&Aに関連する最新のQ&A

A 回答 (3件)

書かれているスクリプトだけでは問題になるようなところは見受けられません。


可能性的には低いと思いますが、もしMySQLをANSIモードで起動している場合は
「"」は文字列引用符としては使用できませんので確認されてはどうでしょうか?
    • good
    • 0

レスが少し遅れました。

緊急だったらごめんなさい。

ログの書き出しですが、普通だったら http daemon の error log に書き出されているはずだと思いますが。
internal server error ならエラーの内容がブラウザにかえってこないので、確認してください。
ただし、IIS は私の範囲外なので、よくわかりません。

あとは、原因の切り分けです。
perl script を確実に動くレベルまで小さくして、Connect, prepare, execute, fetch, disconnect と一段階づつデバッグしていくしかないのでは?
明らかに文法違いは問題外ですが。

とにかく、ログをよく見てください。
    • good
    • 0

これっておそらく perl の DBI & DBD::MySQL だと思うのですが?



もしそうなら、ログを吐き出していると思うので読んでみては。
また、DBD::MySQL はきちんと動作しているのでしょうか?

この回答への補足

解答して頂き本当にありがとうございます。

■これっておそらく perl の DBI & DBD::MySQL だと思うのですが?

まさにとの通りです。

■ログを吐き出していると思うので読んでみては

ログの吐き出し方をお手数ですが、おしえていただけないでしょうか ?

■DBD::MySQL はきちんと動作しているのでしょうか?

違うプログラムで動作を確認しました。

補足日時:2001/09/19 15:17
    • good
    • 0

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

このQ&Aと関連する良く見られている質問

Q${str}と$strの違いとは?

スカラー変数の${str}と$strの違いとは何なのでしょうか。

スカラー変数における{}の意味がよくわかりません。
別になくても処理は変わらない気がしますが、
どういった際に{}は使用するのでしょうか?

Aベストアンサー

もしPerlでのことでしたら、スカラー変数名を{}で囲むのは、それ以降に半角文字が続く場合に、そのスカラー変数名と半角文字の文字列との境界を明示するためだと思います。 変数自体に何かの違いがあるということではないはずです。

たとえば、処理の中でスカラー変数$strに続けてstrという文字を書き出したい場合、「$strstr」と記述すると、[$str]とは別の[$strstr]という名前のスカラー変数と認識されてしまいます。 これを避けるために、スカラー変数名を{}で囲って、「${str}str」と記述することで、$strというスカラー変数に、strという文字が続いていると認識させる、という具合だと思います。

見当違いでしたらごめんなさい。

Q$ENV{'REMOTE_HOST'}について

CGIにて$ENV{'REMOTE_HOST'}を取得したところ
スパム投稿なのですが、$ENV{'REMOTE_HOST'}が
IPアドレスの値である142.54.182.186が入っていました。
普通はkd182249232116.au-net.ne.jp
などという形になると思うのですが
142.54.182.186
となっていることが通常ありえるのでしょうか?
リモートホストを取得し、IPアドレスの形式であった場合、
この投稿者を弾いてしまっても問題ありませんか?

Aベストアンサー

IPアドレスが入っているか、ホスト名が得られるかは、Apacheの設定によります。
ホスト名を得る設定になっていてもDNSの逆引きがその時たまたま失敗すると、IPアドレスのまま設定されます。
なので、「ホスト名が入っていたら儲けもの」くらいの感覚で扱うのがよいかと。

Q引数処理に$ENV{'PATH_INFO'}を用いた際のクッキーについて

自作cgiの引数を $ENV{'PATH_INFO'}を用いた形式
(hoge.cgi/aaa/bbb/cccという形式)に変更しました。

ところが、組み込んでいるアクセス解析用のクッキーが
本来ならば hoge.cgiに対してクッキー1個となるはずですが、

hoge.cgi で1個目
hoge.cgi/aaa で2個目
hoge.cgi/aaa/bbb で3個目
hoge.cgi/ccc で4個目
 ・・
と、引数が変わるたびに発行されてしまいます。
ブラウザで確認すると同じ内容のクッキーが
アクセスした際の引数の分だけズラズラと羅列されています。

本来あるべき形である hoge.cgiに対してクッキー1個にするには
どのようにしたら良いのでしょうか。

Aベストアンサー

Cookie出力の際にパスを設定すれば大丈夫です。指定方法は参考URLを見てください。
とりあえず path=/ をつければ大丈夫ですが、詳細に指定することもできます。
例えば hoge.cgi のURLが
  http://www.example.com/foo/hoge.cgi
だとしたら、path=/foo とすることで
  http://www.example.com/bar/hoge.cgi
などにはCookieが送信されなくなります。
また、www がなくてもアクセスできるページである場合には、domain=.example.com も追加することで
  http://www.example.com/foo/hoge.cgi
にも
  http://example.com/foo/hoge.cgi
にもCookieが送信されるようになります。
(これをしないと、www付きで発行したCookieが、wwwなしの方に送信されません。)

参考URL:http://www.tohoho-web.com/wwwcook.htm#CookieWrite

Cookie出力の際にパスを設定すれば大丈夫です。指定方法は参考URLを見てください。
とりあえず path=/ をつければ大丈夫ですが、詳細に指定することもできます。
例えば hoge.cgi のURLが
  http://www.example.com/foo/hoge.cgi
だとしたら、path=/foo とすることで
  http://www.example.com/bar/hoge.cgi
などにはCookieが送信されなくなります。
また、www がなくてもアクセスできるページである場合には、domain=.example.com も追加することで
  http://www.example.com/foo/hoge.cgi
にも
...続きを読む

Q$ENV{'QUERY_STRING'}以外で引数を取得するには?

CGI上で$ENV{'QUERY_STRING'}を使用しないで引数を取得するにはどうしたらいいのでしょうか?

hoge.cgi?XXXX の XXXX を取得したいのですがある理由によって$ENV{'QUERY_STRING'}が使用できません。

よろしくお願いいたします。

Aベストアンサー

hoge.cgi?xxxx ではなく、
hoge.cgi/xxxx という表記のURIが許されるなら、
$ENV{'PATH_INFO'}を使う方法があります。

QCGIで<br>の表記の仕方

タイトルの通りです。
CGIを作ろうとしているのですが、<br>を表示したいと思っています。
どう表記したら良いのでしょう。
素人的に¥”<br¥”>としましたがうまく行かなかったです。
よろしくお願いします。

Aベストアンサー

もしかして、ブラウザで見たときに「<br>」と見えるようにしたい、ということでしょうか?

だとすると、CGI や perl の問題ではなく HTML の範囲ですね。

print "&lt;br&gt;";

でいけるのでは?


このカテゴリの人気Q&Aランキング

おすすめ情報