質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.12%

データベースのデータをtableviewに代入したいのですが、うまくできません。どなたか助けていただけませんか?よろしくお願いいたします。

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 280

L4zy

score 6

【SampleController.java】
package application;

import java.net.URL;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ResourceBundle;

import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.fxml.FXML;
import javafx.scene.control.TableView;

public class SampleController {

@FXML
private ResourceBundle resources;

@FXML
private URL location;

@FXML
private TableView<?> tableview;

@FXML
void initialize() {
assert tableview != null : "fx:id=\"tableview\" was not injected: check your FXML file 'Sample.fxml'.";
DB();
}

public static void DB() {

Connection connection = null;
PreparedStatement pre_statement = null;
ResultSet result_set = null;

ObservableList<ObservableList> data = FXCollections.observableArrayList();

try {
//MySQLの接続
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/orderdb?characterEncoding=UTF-8&serverTimezone=JST", "root", "パスワード");

//接続しているデータベース名を表示
System.out.println("MySQLに接続できました。");
System.out.println("getCatalog:" + connection.getCatalog() + "\r\n");

pre_statement = connection.prepareStatement("select * from goods limit 10");
result_set = pre_statement.executeQuery();

while(result_set.next()) {

data.clear();

//一行ずつ(カラム)
ObservableList<String> row = FXCollections.observableArrayList();

for(int i = 1; i <= result_set.getMetaData().getColumnCount(); i++) {

//iはカラム番号
row.add(result_set.getString(i));
}
data.add(row);
System.out.println(data); ←ここでは正確にが出力されす。
}

//テーブルビューに値代入
tableview.setItems(data); ←ここでエラーが出ます

// データベースとの接続に失敗した場合
}catch(SQLException ex) {

ex.printStackTrace();
System.err.println("MySQLに接続できませんでした。");

}finally {
closeSQL(connection, pre_statement, result_set);
}
}

static void closeSQL(Connection connection, PreparedStatement pre_statement, ResultSet result_set) {
try {
// データベースとの接続を解除
if (connection != null) {
connection.close();
}

if (pre_statement != null) {
pre_statement.close();
}

if (result_set != null) {
result_set.close();
}

}catch(SQLException ex) {
System.err.println("Error closeSql Func");
//どこで、エラーが起こっているかが分かる
ex.printStackTrace();
}
}

}

【Main.java】
package application;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.scene.layout.AnchorPane;
import javafx.stage.Stage;

public class Main extends Application {
@Override
public void start(Stage primaryStage) {
try {
AnchorPane root = (AnchorPane)FXMLLoader.load(getClass().getResource("Sample.fxml"));
Scene scene = new Scene(root,600,400);
scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
primaryStage.setScene(scene);
primaryStage.show();
} catch(Exception e) {
e.printStackTrace();
}
}

public static void main(String[] args) {
launch(args);
}
}

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Orlofsky

    2019/08/16 22:08

    コードは https://teratail.com/help/question-tips#questionTips3-7 の [コード] に修正してください。

    キャンセル

  • Orlofsky

    2019/08/17 10:04

    markdown 程度を理解ができないと、この仕事は辛いですよ。

    キャンセル

  • L4zy

    2019/08/17 10:27

    分らないのなら大丈夫です。

    キャンセル

  • 退会済みユーザー

    2019/08/24 00:54

    複数のユーザーから「やってほしいことだけを記載した丸投げの質問」という意見がありました
    「質問を編集する」ボタンから編集を行い、調査したこと・試したことを記入していただくと、回答が得られやすくなります。

回答 1

0

データは取得できているそうなので、TableViewへの設定が問題なのかなと思います。
error内容も記載していただけるとよいと思います。

@FXML
private TableView<?> tableview;

TableViewの型が指定されていないため、型を指定してください。
(goodsテーブルのカラム名のクラスを作るとよいと思います。)

tableview.setItems(data);


ここはdataではなくfor文の外で

setItems(ObservableList<goodsのクラス>)


とするとよいかなと思います。
また、TableViewはあるのにTableColumnがないのでTableColumnを作る必要があります。
またTableColumnへのデータのバインドもしないと表示できないので。

一度、調べて再度学習してみるといいと思います。
http://www.02.246.ne.jp/~torutk/javafx2/table/tableview-memo.html

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる
  • トップ
  • Javaに関する質問
  • データベースのデータをtableviewに代入したいのですが、うまくできません。どなたか助けていただけませんか?よろしくお願いいたします。