JavaFX MySQL TableView Как выбрать строку и добавить ее во второй TableView (и добавить значение в БД)? - PullRequest
0 голосов
/ 20 января 2019

Я пытаюсь выяснить, как взять значение строки в одном TableView и добавить его в другой TableView (а также записать значение строки в файл SQL). В основном, я загружаю меню слева и хочу добавить пункт меню справа (порядок). У меня много проблем с выяснением того, как обработать событие «Добавить элемент в заказ». Любое направление будет очень цениться!

Я не могу понять, как обрабатывать метод addItemToOrder (), потому что, кажется, есть некоторое расхождение, которое я не учитываю.

package sample;

import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.fxml.Initializable;
import java.net.URL;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ResourceBundle;
import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.scene.control.*;
import javafx.scene.control.cell.PropertyValueFactory;

public class Controller implements Initializable {

@FXML
private Label label;
@FXML
private TableView<MenuDetails> tableMenu;
@FXML
private TableColumn<MenuDetails, String> columnItemId;
@FXML
private TableColumn<MenuDetails, String> columnItemName;
@FXML
private TableColumn<MenuDetails, String> columnItemCost;
@FXML
private Button btnLoad;

@FXML
private TableView<OrderDetails> tableOrder;
@FXML
private TableColumn<OrderDetails, String> columnOrderNumber;
@FXML
private TableColumn<OrderDetails, String> columnItemNumber;
@FXML
private TableColumn<OrderDetails, String> columnItemNameOrder;
@FXML
private TableColumn<OrderDetails, String> columnItemCostOrder;
@FXML
private Button btnAdd;

/** Initialize observable list to hold database data */
private ObservableList<MenuDetails> data;
private ObservableList<OrderDetails> data2;
private Connection connection = null;
private PreparedStatement preparedStatement = null;

@Override
public void initialize(URL url, ResourceBundle rb) {
    connection = DbConnection.Connect();
}

@FXML
private void loadDataFromDatabase(ActionEvent event) {

    try {
        connection = DbConnection.Connect();
        data = FXCollections.observableArrayList();

        /** Execute query and store result in a resultSet */
        ResultSet rs = connection.createStatement().executeQuery(
                "SELECT * FROM menu;");

        while (rs.next()) {
            data.add(new MenuDetails(rs.getString("item_id"),
                    rs.getString("item_name"),
                    rs.getString("item_cost")));
        }

    } catch (SQLException ex) {
        ex.printStackTrace();
    }

    /** Set cell value factory to tableview
     * NB.PropertyValue Factory must be the same */
    columnItemId.setCellValueFactory(new PropertyValueFactory<>("item_id"));
    columnItemName.setCellValueFactory(new PropertyValueFactory<>("item_name"));
    columnItemCost.setCellValueFactory(new PropertyValueFactory<>("item_cost"));

    tableMenu.setItems(null);
    tableMenu.setItems(data);

}
@FXML
private void addItemToOrder(ActionEvent event) throws SQLException {

    String sql = "INSERT INTO orders" +
            "(item_number,item_name,item_cost) " +
            "VALUES(?,?,?)";

    String itemNumber = columnItemId.getCellData(1);
    String itemName = columnItemName.getCellData(2);
    String itemCost = columnItemCost.getCellData(3);



    try {
        connection = DbConnection.Connect();
        preparedStatement = connection.prepareStatement(sql);
        preparedStatement.setString(1, itemNumber);
        preparedStatement.setString(2, itemName);
        preparedStatement.setString(3, itemCost);


        int i = preparedStatement.executeUpdate();
        if (i == 1) {
            System.out.println("Data Insert Successful");
        }

        data2 = FXCollections.observableArrayList();

    } catch (SQLException ex) {
        ex.printStackTrace();
    } finally {
        preparedStatement.close();
    }

    /** Set cell value factory to tableview
     * NB.PropertyValue Factory must be the same */
    columnItemNumber.setCellValueFactory(new PropertyValueFactory<>("item_number"));
    columnItemNameOrder.setCellValueFactory(new PropertyValueFactory<>("item_name"));
    columnItemCostOrder.setCellValueFactory(new PropertyValueFactory<>("item_cost"));

    tableOrder.setItems(null);
    tableOrder.setItems(data2);

}

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...