- - PR -
二次元配列の参照
1
| 投稿者 | 投稿内容 | ||||
|---|---|---|---|---|---|
|
投稿日時: 2003-06-13 21:38
javaの初心者です。よろしくお願いします。
二次元配列の内容を参照したいのですが、思うような結果になりません。 いい方法があったら教えて下さい。 String seikyu1[][]; 〜 dbc = new DB_CONNECT(); 〜 seikyu1 = dbc.getSeikyu_Gamen1(w_nendo, w_seqno); 〜 if (seikyu1[14][0].equals("00")) { 処理; } 上記のような感じです。 二次元配列にデータベース検索した値を返し、その内容を参照しています。 seikyu1[14][0]の内容は00に間違いはないのですが、if文はfalseを返します。 compareToも使ってみたのですが、これもfalseを返します。 配列じゃないstringクラスに代入してから比較したり、いろいろやってみたのですが、 うまくいきませんでした。 | ||||
|
投稿日時: 2003-06-13 23:46
はじめまして、わっき〜と申します。どうぞよろしくです。
さて、ご質問の件ですが・・・ この質問ではあまりにも色々と可能性が考えられすぎます。 非常に素人くさい試し方ですが、 1)seikyu1[14][0]をprintしてみる 2)dbc.getSeikyu_Gamen1()[14][0]をprintしてみる 3)getSeikyu_Gamen1()の中で当該データをprintしてみる といった感じで一つずつつぶしてみてはどうでしょう? さらに、ただprintするのではなく System.out.println( "(" + seikyu1[14][0] + ")" ); のようにして、前後をびっちりはさんであげれば、余計な文字が含まれて いないかどうか確かめられます。 いかがでしょう? | ||||
|
投稿日時: 2003-06-16 09:35
こんにちは、ありぱぱです。
わっき〜さん、ありがとうございます。 ""をつけて表示してみたら、"00 "となっていました。 間違って余計な空白が入ったのかと思って、 "00 "で比較してみたのですが、if文はfalseになってしまいました。 他の項目も調べてみたら、後ろに空白?が入っていました。 どうやらデータベースの作り方に問題があるようです。 いいテスト方法を教えていただきました。 これで先に進めそうです。感謝感謝です。 | ||||
|
投稿日時: 2003-06-16 21:36
ありぱぱさんの書き込み (2003-06-16 09:35) より:
>どうやらデータベースの作り方に問題があるようです。 データベースの該当カラムの型が固定長文字列になっていませんか? | ||||
|
投稿日時: 2003-06-17 08:38
そのとおりでした。 可変長文字列にしたら、後ろの空白?が無くなりました。 基本的なことなのかもしれませんが、 データベース項目の固定長と可変長で何が違ってくるのか 教えていただけますか。 | ||||
|
投稿日時: 2003-06-17 09:21
文字通りデータの長さが変わります。 用途にもよりますが・・・ 固定長のデータを比較する場合は必ず trim() してあげてください。 固定長文字列などの場合、結合時にSQL関数で trim してあげないと いけないし、INDEXが使われないなどの問題がありますので あまり好きではありませんが(^^; | ||||
|
投稿日時: 2003-06-17 10:24
> 基本的なことなのかもしれませんが、
> データベース項目の固定長と可変長で何が違ってくるのか > 教えていただけますか。 本当に基本的なことなので、DBの入門書など参考にしてみてください。 実装方法を想像してみたら違いもわかりやすいかもしれないですね。 | ||||
1
