2

在我的项目中,员工插入一个表号,选择客户订购的所有项目并将其保存到数据库中。我有三张桌子:

Employee(empId, firstname, lastname)
Orders(orderId,tableNum,empIDFK,itemIDFK,totalPrice) 
Item(itemId,itemName, itemPrice)

我的问题是,如果员工在订单中放置了多个项目,则只会将最后一个项目保存在 itemIDFK 列中。如何获取员工输入的所有项目的 ID?

在此处输入图像描述

这是一些示例代码,大多数按钮都有类似的代码:

 private void chickenbuttonActionPerformed(java.awt.event.ActionEvent evt) {                                              
    // TODO add your handling code here:
     try{
     st = connection.createStatement();   
    String query;
    query = "SELECT itemName, itemPrice FROM item WHERE itemID = '14446'";
    String itemName = " ",itemPrice =" ";  

      ResultSet rs = st.executeQuery(query);

       if(rs != null){
        while(rs.next())
        { 
         itemName = rs.getString(1);
         itemPrice = rs.getString(2);
        }
     model.addRow(new Object[]{itemName, itemPrice});
      total+= Double.parseDouble(itemPrice);
       String format = formatter.format(total);
       totalField.setText(format);
       }

       //inserts corresponding item id in itemIDFK 
      String query2 = "Update orders SET itemIDFK = '14446' Where tableNum =  " + tableNum;
      ps= connection.prepareStatement(query2);
      ps.executeUpdate();
         } catch (SQLException ex) {}
4

3 回答 3

5

在这种情况下,您要做的是添加另一个表,例如OrderDetails,该表将具有:

PK: Id
FK: OrderId
FK: ItemId

因此,您可以将多个项目添加到订单中。会有一个one-to-many介于OrderandOrderDetailsmany-to-manybetween OrderDetailsandItems

于 2013-04-28T21:23:22.883 回答
2

SOfanatic 的答案是正确的方法。如果由于某种原因您无法添加另一个表,则itemIDFK需要保存一个分隔的项目列表,例如itemId;itemId;itemId(或者itemiditemIditemId如果 id 是固定宽度) - 问题是这更难查询

于 2013-04-28T21:25:16.097 回答
0

MySQL 确实有一种数据类型 Serial。因此,还有另一种方法可以实现具有多个项目和不同数量项目的订单。

可以实现一个 Arraylist<>,序列化和反序列化数据进出单个列。

于 2021-02-14T02:13:41.400 回答