
DB:SQL Server 2005
JDBCを使ってデータベースへアクセスし、SQL発行して結果をResultsetに格納、getStringで各項目の値を取得するところまでは確認できています。
外部結合したテーブルを参照していおり、getString()でnullを取得した場合にjava.lang.NullPointerExceptionが返ってエラーとなってしまいます。
回避策はあるのでしょうか?
抜粋したソースを下記に記します。
-- test.jsp --
<%
ResultSet rs = db.executeQuery(sql);
while(rs.next()){
String disp_object = rs.getString("object");
if(disp_object == null) disp_object="---";
}
%>
<tr>Object</tr>
<tr><%=disp_object%></tr>
No.2ベストアンサー
- 回答日時:
<%
ResultSet rs = db.executeQuery(sql);
String disp_object = "---";
while(rs.next()){
disp_object = rs.getString("object");
if (disp_object == null) {
disp_object = "---";
}
}
%>
<tr>Object</tr>
<tr><%=disp_object%></tr>
これでどうです?
※ ProKaseifuさんの回答にある記述でも
NullPointerは発生しないような気もしますが・・・?
御回答有難う御座います
すみません、自己解決しました。。。
結果的に、NullPointerが発生している箇所が私の質問した箇所と異なっていたという最悪の結果でした。
「getString()ではnullの値を読む時にエラーが発生する」となぜか勝手に解釈をしていましたが、実際にはその文字列を操作した時に発生していました。
大変、御手数をお掛け致しました(/-T);
恥ずかしながら該当する箇所を記載致します。
String discom1; // ページに表示する値。
String com = rs.getString("comment"); // commentの値をcomに格納
if(com.length() > 5)discom1 = com.substring(0, 5) + ".."; // 文字数が6文字以上は「aaaaa..」と表示
という箇所を
String discom1="";
String com="";
if(com1 != null){
if(com1.length() > 5)discom1 = com1.substring(0, 5) + "..";
}
としただけです。
ProKaseifulさん並びにpug0429さん、大変失礼をいたしました。
No.1
- 回答日時:
変数のスコープがおかしいですよ。
<%
ResultSet rs = db.executeQuery(sql);
String disp_object = "---";
while(rs.next()){
disp_object = rs.getString("object");
}
%>
<tr>Object</tr>
<tr><%=disp_object%></tr>
御解答有難う御座います。
String disp_object = "---";
を追加してみましたが、やはり結果は同じjava.lang.NullPointerExceptionが返ってきました。
NULL値を参照する場合の常套手段というのは何かあるのでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript EasyUIのSubGrid(jquery)におけるObjectに入れた連想配列について 1 2022/05/02 11:21
- PHP クエリObjectをforeachで回す時に、次のレコードへ移動せずに次のレコードを取得したい 2 2022/07/28 15:29
- Visual Basic(VBA) access count数を変数に格納 2 2022/03/30 19:21
- C言語・C++・C# C# DatagridviewにExcelシートを反映するとエラーが出る 2 2023/05/06 17:12
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
- PostgreSQL DBFluteについて質問です。 環境:PostgreSQL java8 前提:webアプリケーショ 1 2022/07/07 00:49
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- AJAX JavascriptからPHPへのAjax通信でnullが返ってくる 3 2022/08/03 22:00
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列にnullを代入すると、null...
-
ORA-01858: 数値を指定する箇所...
-
入力された文字列の制限
-
C# ListBoxのインデックスの値...
-
eclipseでoracle接続時のエラー...
-
JavaScriptのnullはいつ使う?
-
javaの掲示板について
-
空欄のテキストフィールドの判...
-
getStringの値がNULLの時の処理
-
System.err. printlnとSystem.o...
-
EclipseでJava
-
Javaで文字と数字が混ざったも...
-
わかりません
-
java キーボード入力された値の...
-
IF関数でEmpty値を設定する方法。
-
意味がわかりません
-
コンパイルできません
-
変数を動的に利用するには?
-
Stringクラスの変数の格納アド...
-
挿入演算子<<をオーバーロード...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ORA-01858: 数値を指定する箇所...
-
配列にnullを代入すると、null...
-
BOOL値を逆にしたい
-
getStringの値がNULLの時の処理
-
Java配列でNullPointerExceptio...
-
javaの掲示板について
-
eclipseでoracle接続時のエラー...
-
C#でラジオボタンとコンボボッ...
-
例外でBeanUtils.populateが、...
-
C# ListBoxのインデックスの値...
-
逆コンパイルの見方について(...
-
Tomcatを再起動するとエラーが...
-
空欄のテキストフィールドの判...
-
jsp/Servletの動的に増えるフォ...
-
プログラミングの質問です
-
入力された文字列の制限
-
androidアプリが強制終了してし...
-
if文を通らない
-
サーブレット、JSP、Mysqlについて
-
Stringを返す getText()メソッ...
おすすめ情報