日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

西工大数据库实验大作业 火锅店菜品管理系统

發布時間:2024/3/26 windows 63 豆豆
生活随笔 收集整理的這篇文章主要介紹了 西工大数据库实验大作业 火锅店菜品管理系统 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

西工大數據庫實驗大作業 火鍋店菜品管理系統

文章目錄

  • 西工大數據庫實驗大作業 火鍋店菜品管理系統
    • 前言:
    • 一.大作業簡單的需求分析:
    • 二.數據流圖:
    • 三.數據字典:
    • 四.E-R圖:
    • 五.關系模式設計:
    • 六.各種視圖以及各種約束、存儲過程、觸發器腳本描述:
        • 1.視圖:
        • 2.約束:
        • 3.存儲過程:
        • 4.觸發器:
        • 5.索引設計:
    • 七.大作業環境配置:
    • 八.大作業界面效果演示:
    • 九.關于源代碼:
        • 1.關于JDBC的演示:
        • 2.關于Food實體的演示:
        • 3.關于FoodDao類的演示:
        • 4.關于主界面mainframe設計的代碼:
        • 5.關于菜品添加界面FoodAddInterFirm設計的代碼:
        • 6.關于菜品信息管理界面FoodManageInterFirm設計的代碼:

前言:

本學期數據庫實驗結束了,在最后的大作業階段,經過本人調研結合所學之后,結合MySQL JDBC Java Swing等技術整合出的此系統,其中相關的學習視頻參考鏈接在:B站學習視頻:圖書管理系統,本篇將以實驗報告的形式對本系統做出相關的介紹

一.大作業簡單的需求分析:

本次實驗中本人所設計的系統是“河底撈”火鍋店的菜品管理系統,“民以食為天”,此系統正是本人在吃飯時尋找到的實驗靈感。通過采訪和調研火鍋店的服務員以及經理,將火鍋店背后完整的系統進行分析與設計。其中作為火鍋店的經理,即對于菜品部分專門負責的經理需掌握三個方面的管理:第一是關于菜品類別的管理,即火鍋店中涉及的菜品需進行分類,如:底料,葷菜,素菜等等,分門別類會更加便于管理;第二是關于菜品的管理,同時也是本系統的核心,一個菜品管理系統中通過記錄各種菜品對應的儲量,售價,分類等等才能更高效的保證火鍋店的經營;第三是供貨商管理,針對一個火鍋店的菜品,當菜品的儲量較低時需要進貨,這就牽扯到了供貨商進貨的問題了,因此將一個菜品管理系統整個就分成這么三部分的管理內容:菜品類別,菜品,供貨商,轉化為數據庫中即將三者分別設計為實體,并通過對于三個實體的增刪改查操作來管理和維護整個菜品管理系統。

二.數據流圖:

頂層數據流圖:

0層數據流圖:

三.數據字典:

數據加工:

元素編號名稱類型說明
B01菜品管理系統處理對菜品類別,菜品和供貨商進行管理的系統進行加工
B02登錄系統處理菜品管理系統的登錄界面
S01身份信息數據流管理員的身份信息
S02菜品類別信息數據流菜品的類別名稱以及菜品類別描述
S03菜品信息數據流菜品名稱,菜品儲備,菜品售價,菜品所屬類別以及菜品描述
S04供貨商信息數據流供貨商姓名,供貨商聯系電話,供應菜品以及供應價格
IP01菜品類別管理處理添加菜品類別和菜品類別具體管理兩個模塊
IP02菜品管理處理添加菜品和菜品具體管理兩個模塊
IP03供貨商管理處理添加供貨商和供貨商具體管理兩個模塊
IP04菜品類別添加處理添加菜品類別名稱以及菜品類別描述
IP05菜品類別具體管理處理對菜品類別進行增刪改查
IP06菜品添加處理添加菜品名稱,菜品儲備,菜品售價,菜品所屬類別以及菜品描述
IP07菜品具體管理處理對菜品進行增刪改查
IP08供貨商添加處理添加供貨商姓名,供貨商聯系電話,供應菜品以及供應價格
IP09供貨商具體管理處理對供應商進行增刪改查

數據流:

  • 數據流名稱:S01身份信息:
數據項數據類型長度備注
user_idint整型管理員編號
user_namevarchar45管理員姓名
user_passwordvarchar45管理員密碼
  • 數據流名稱:S02菜品類別信息:
數據項數據類型長度備注
foodtype_idint整型菜品類型編號
foodtype_namevarchar45菜品類型名稱
foodtype_descvarchar45菜品類型描述
  • 數據流名稱:S03菜品信息:
數據項數據類型長度備注
food_idint整型菜品編號
food_namevarchar45菜品名稱
food_storageint整型菜品儲備(單位:份)
food_pricefloat浮點型菜品售價(單位:元/份)
food_typeidint整型菜品所屬類別
food_descvarchar45菜品描述
  • 數據流名稱:S04供應商信息:
數據項數據類型長度備注
s_idint整型供貨商編號
s_namevarchar45供貨商姓名
s_telvarchar45供貨商電話
s_foodidint整型供應菜品編號
s_pricefloat浮點型供應價格(單位:元/份)

四.E-R圖:

五.關系模式設計:

在E-R圖中出現的實體有:

  • 管理員{編號,姓名,密碼,(編號->姓名,編號->密碼)};
  • 菜品類別{編號,名稱,描述,(編號->名稱,編號->描述)};
  • 菜品{編號,名稱,儲備,售價,所屬類別,描述(編號->名稱,編號->儲備,編號->售價,編號->所屬類別,編號->描述)},其中所屬類別作為菜品類別中編號的外碼;
  • 供應商{編號,姓名,電話,供應菜品,供應價,(編號->姓名,編號->電話,編號->供應菜品,編號->供應價)},其中供應菜品作為菜品中編號的外碼;

則在上面的描述中對應各個關系實體有:

  • 1)在整個設計中各個實體中的屬性不可分割且獨立,則符合1NF
  • 2)各個實體中的屬性不存在對碼的傳遞依賴和部分依賴,則符合2NF,3NF

六.各種視圖以及各種約束、存儲過程、觸發器腳本描述:

1.視圖:

由于本系統是面向全體管理員的,因此不需要使用視圖來進行安全性和查詢上面的一些維護

2.約束:

  • 在上面的設計中對于每個關系的主鍵,三個關系中的編號均設置為PRIMARY KEY,并且都要求NOT NULL以及ATUO INCREMENT
  • 對于四個關系之間存在兩個外鍵,即:菜品的所屬類別與菜品的編號之間,供應商的供應菜品與菜品的編號之間,具體如下:
  • 針對某些列中設計的CHECK約束,在建好的表上使用alter添加約束:
-- 菜品儲備必須>=0: alter table food add constraint check_storage check(food_storage>0); -- 菜品中售價必須>0: alter table food add constraint check_price check(food_price>0); -- 供應價格必須>0: alter table supply add constraint check_price_s check(s_price>0);

運行結果:

3.存儲過程:

本存儲過程用于更新售價,假定所有菜品的售價是基于供貨商供應價而定的,并且利潤為40%,即在更新供應價格后結合觸發器對于售價進行改變,于是定義的存儲過程如下:

delimiter$$ create procedure `changeprice` (in foodid int,in price_in float) begin declare price_out float; select s_price into price_in from supply where s_id = foodid; set price_out = price_in*1.4; update food set food_price = price_out where food_id = foodid; end $$

運行結果:

4.觸發器:

本系統中的觸發器即是結合上面設計的存儲過程在供應商表發生變化時執行上面的存儲過程并獲得輸出,后利用輸出更新菜品表中的售價,具體如下:

delimiter $$ -- 添加插入觸發器 create trigger `update_price_on_food` after insert on supply for each row begin call `changeprice` (new.s_foodid,new.s_price); end $$ -- 添加更新觸發器 create trigger `update_price_on_food_update` after update on supply for each row begin call `changeprice` (new.s_foodid,new.s_price); end $$

運行結果:

5.索引設計:

針對數據量較大的關系中頻繁使用的查詢條件增加索引:菜品中的菜品名稱列增加對應的索引,具體如下:

七.大作業環境配置:

  • mysql版本:mysql 8.0
  • 實現系統界面使用的語言:java
  • 使用的IDE:eclipse
  • 使用的完成界面的插件:WindowBuilder

八.大作業界面效果演示:

  • 登錄界面:
  • 主界面:
  • 關于我們界面:
  • 菜品數據維護中的菜單截圖:
  • 菜品類別添加界面:
  • 菜品類別管理界面:
  • 菜品添加界面:
  • 菜品管理界面:
  • 供貨商添加界面:
  • 供貨商信息更改界面:
  • 安全退出:

九.關于源代碼:

本次在代碼編程時使用的是java語言,其中設計符合model-dao-view的模式,并且將JDBC連接和字符串判空的工具類放在utils目錄中,將圖片放在images目錄中,關于代碼的結構如下圖所示:

1.關于JDBC的演示:

import java.sql.Connection; import java.sql.DriverManager;public class JDBCtest {//配置JDBC連接的基本參數:private static String dbURL = "jdbc:mysql:///bighomework?useSSL=false&serverTimezone=UTC&characterEncoding=UTF-8&allowPublicKeyRetrieval=true";private static String dbUSERNAME = "root";private static String dbPASSWORD = "123456";private static String JDBCname="com.mysql.cj.jdbc.Driver";//獲取數據庫的連接public static Connection getCon() throws Exception{Class.forName(JDBCname);Connection conn = DriverManager.getConnection(dbURL, dbUSERNAME, dbPASSWORD);return conn;}//關閉數據庫連接(占用內存很多)public static void closeCon(Connection conn) throws Exception{if(conn!=null){conn.close();}}public static void main(String[] args) throws Exception{JDBCtest jdbc = new JDBCtest();try{Connection conn = jdbc.getCon();System.out.println("數據庫連接成功!");System.out.println(conn);jdbc.closeCon(conn);} catch (Exception e) {e.printStackTrace();System.out.println("數據庫連接失敗!");}} }

2.關于Food實體的演示:

//菜品的實體 public class Food {private int id; //菜品編號private String name; //菜品名稱private int storage; //菜品存貨(份)private float price; //菜品售賣價格private int typeid; //菜品類別idprivate String typename; //菜品類別名稱private String desc; //菜品描述//供貨商階段會用到的構造方法:public String getTypename() {return typename;}public Food(String name) {super();this.name = name;}public Food(String name, int typeid) {super();this.name = name;this.typeid = typeid;}public void setTypename(String typename) {this.typename = typename;}public Integer getTypeid() {return typeid;}public Food(int id, String name, int storage, float price, int typeid, String desc) {super();this.id = id;this.name = name;this.storage = storage;this.price = price;this.typeid = typeid;this.desc = desc;}public Food(String name, int storage, float price, int typeid, String desc) {super();this.name = name;this.storage = storage;this.price = price;this.typeid = typeid;this.desc = desc;}public void setTypeid(int typeid) {this.typeid = typeid;}public Food() {super();}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getStorage() {return storage;}public void setStorage(int storage) {this.storage = storage;}public float getPrice() {return price;}public void setPrice(float price) {this.price = price;}public String getDesc() {return desc;}public void setDesc(String desc) {this.desc = desc;}@Overridepublic String toString() {return name;} }

3.關于FoodDao類的演示:

import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import jdbc.model.Food; import jdbc.utils.StringUtil;//菜品的Dao類 public class FoodDao {//菜品添加函數:public int add(Connection conn,Food food) throws Exception{String sql = "insert into food values(null,?,?,?,?,?)";PreparedStatement pstmt = conn.prepareStatement(sql);pstmt.setString(1,food.getName());pstmt.setInt(2,food.getStorage());pstmt.setFloat(3,food.getPrice());pstmt.setInt(4, food.getTypeid());pstmt.setString(5,food.getDesc());return pstmt.executeUpdate();}//菜品信息查詢:public ResultSet list(Connection conn,Food food)throws Exception {StringBuffer sb = new StringBuffer("select * from food f,food_type ft where f.food_typeid = ft.foodtype_id");if(StringUtil.isNotEmpty(food.getName())){sb.append(" and f.food_name like '%" + food.getName() +"%'");}if(food.getTypeid()!= null && food.getTypeid()!=-1 && food.getTypeid()!= 0) {sb.append(" and f.food_typeid ="+food.getTypeid());}PreparedStatement pstmt = conn.prepareStatement(sb.toString());return pstmt.executeQuery();}//菜品信息刪除:public int delete(Connection conn,String id)throws Exception{String sql = "delete from food where food_id=?";PreparedStatement pstmt = conn.prepareStatement(sql);pstmt.setString(1, id);return pstmt.executeUpdate();}//菜品信息修改:public int update(Connection conn,Food food)throws Exception{String sql = "update food set food_name=?,food_storage=?,food_price=?,food_typeid=?,food_desc=? where food_id=?";PreparedStatement pstmt = conn.prepareStatement(sql);pstmt.setString(1, food.getName());pstmt.setInt(2, food.getStorage());pstmt.setFloat(3, food.getPrice());pstmt.setInt(4, food.getTypeid());pstmt.setString(5, food.getDesc());pstmt.setInt(6, food.getId());return pstmt.executeUpdate();}//判斷菜品類型下是否有菜品:public boolean existFoodByFoodTypeId(Connection conn,String foodtypeid)throws Exception{String sql = "select * from food where food_typeid = ?";PreparedStatement pstmt = conn.prepareStatement(sql);pstmt.setString(1, foodtypeid);ResultSet rs = pstmt.executeQuery();return rs.next(); }//初始化供貨商下拉框:public ResultSet list_supply(Connection conn,Food food)throws Exception {StringBuffer sb = new StringBuffer("select * from food");if(StringUtil.isNotEmpty(food.getName())){sb.append(" and foodtype_name like '%"+food.getName()+"%'");}PreparedStatement pstmt = conn.prepareStatement(sb.toString().replaceFirst("and","where"));return pstmt.executeQuery();} }

4.關于主界面mainframe設計的代碼:

import java.awt.BorderLayout; import java.awt.EventQueue;import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.border.EmptyBorder; import javax.swing.JMenuBar; import javax.swing.JMenu; import javax.swing.JMenuItem; import javax.swing.JOptionPane; import javax.swing.GroupLayout; import javax.swing.GroupLayout.Alignment; import javax.swing.JDesktopPane; import java.awt.Color; import java.awt.event.ActionListener; import java.awt.event.ActionEvent; import javax.swing.ImageIcon; import javax.swing.JLabel;public class mainframe extends JFrame {private JPanel contentPane;private JDesktopPane table = null;/*** Launch the application.*/public static void main(String[] args) {EventQueue.invokeLater(new Runnable() {public void run() {try {mainframe frame = new mainframe();frame.setVisible(true);} catch (Exception e) {e.printStackTrace();}}});}/*** Create the frame.*/public mainframe() {setTitle("\u201C\u6CB3\u5E95\u635E\u201D\u83DC\u54C1\u7BA1\u7406\u7CFB\u7EDF\u4E3B\u754C\u9762");setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);setBounds(100, 100, 1550, 790);JMenuBar menuBar = new JMenuBar();setJMenuBar(menuBar);JMenu mnNewMenu = new JMenu("\u83DC\u54C1\u6570\u636E\u7EF4\u62A4");mnNewMenu.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u6570\u636E.png"));menuBar.add(mnNewMenu);JMenu mnNewMenu_2 = new JMenu("\u83DC\u54C1\u7C7B\u522B\u7BA1\u7406");mnNewMenu_2.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7C7B\u522B\u7BA1\u7406.png"));mnNewMenu.add(mnNewMenu_2);JMenuItem mntmNewMenuItem_2 = new JMenuItem("\u83DC\u54C1\u7C7B\u522B\u6DFB\u52A0");mntmNewMenuItem_2.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7C7B\u522B_\u6DFB\u52A0.png"));mntmNewMenuItem_2.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent arg0) {FoodTypeInterFirm foodtypeinterfirm = new FoodTypeInterFirm();foodtypeinterfirm.setVisible(true);table.add(foodtypeinterfirm);}});mnNewMenu_2.add(mntmNewMenuItem_2);JMenuItem mntmNewMenuItem_1 = new JMenuItem("\u83DC\u54C1\u7C7B\u522B\u7EF4\u62A4");mntmNewMenuItem_1.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7C7B\u522B_\u7EF4\u62A4.png"));mntmNewMenuItem_1.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent arg0) {FoodTypeManageInterFirm foodtypemanageinterfirm = new FoodTypeManageInterFirm();foodtypemanageinterfirm.setVisible(true);table.add(foodtypemanageinterfirm);}});mnNewMenu_2.add(mntmNewMenuItem_1);JMenu mnNewMenu_3 = new JMenu("\u83DC\u54C1\u7BA1\u7406");mnNewMenu_3.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7BA1\u7406.png"));mnNewMenu.add(mnNewMenu_3);JMenuItem mntmNewMenuItem_3 = new JMenuItem("\u83DC\u54C1\u6DFB\u52A0");mntmNewMenuItem_3.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1_\u6DFB\u52A0.png"));mntmNewMenuItem_3.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {FoodAddInterFirm foodaddinterfirm = new FoodAddInterFirm();foodaddinterfirm.setVisible(true);table.add(foodaddinterfirm);}});mnNewMenu_3.add(mntmNewMenuItem_3);JMenuItem mntmNewMenuItem_4 = new JMenuItem("\u83DC\u54C1\u7EF4\u62A4");mntmNewMenuItem_4.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1_\u7EF4\u62A4.png"));mntmNewMenuItem_4.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {FoodManageInterFirm foodmanageinterfirm = new FoodManageInterFirm();foodmanageinterfirm.setVisible(true);table.add(foodmanageinterfirm);}});mnNewMenu_3.add(mntmNewMenuItem_4);JMenu mnNewMenu_4 = new JMenu("\u4F9B\u8D27\u5546\u7BA1\u7406");mnNewMenu_4.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u4F9B\u8D27\u5546.png"));mnNewMenu.add(mnNewMenu_4);JMenuItem mntmNewMenuItem_6 = new JMenuItem("\u4F9B\u8D27\u5546\u6DFB\u52A0");mntmNewMenuItem_6.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {SupplyAddInterFirm supplyAddInterFirm = new SupplyAddInterFirm();supplyAddInterFirm.setVisible(true);table.add(supplyAddInterFirm);}});mntmNewMenuItem_6.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u4F9B\u8D27\u5546_\u6DFB\u52A0.png"));mnNewMenu_4.add(mntmNewMenuItem_6);JMenuItem mntmNewMenuItem_7 = new JMenuItem("\u4F9B\u8D27\u5546\u4FE1\u606F\u66F4\u6539");mntmNewMenuItem_7.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {SupplyManageInterFirm supplyManageInterFirm = new SupplyManageInterFirm();supplyManageInterFirm.setVisible(true);table.add(supplyManageInterFirm);}});mntmNewMenuItem_7.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u4F9B\u8D27\u5546_\u7EF4\u62A4.png"));mnNewMenu_4.add(mntmNewMenuItem_7);JMenuItem mntmNewMenuItem_5 = new JMenuItem("\u5B89\u5168\u9000\u51FA");mntmNewMenuItem_5.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u9000\u51FA.png"));mntmNewMenuItem_5.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {int result = JOptionPane.showConfirmDialog(null, "是否退出系統?");//System.out.println(result);if(result == 0) {dispose();}}});mnNewMenu.add(mntmNewMenuItem_5);JMenu mnNewMenu_1 = new JMenu("\u5173\u4E8E\u6211\u4EEC");mnNewMenu_1.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u706B\u95051.png"));menuBar.add(mnNewMenu_1);JMenuItem mntmNewMenuItem = new JMenuItem("\u6CB3\u5E95\u635E\u706B\u9505");mntmNewMenuItem.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u706B\u95052.png"));mntmNewMenuItem.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent arg0) {AboutUsInterFirm aboutusinterfirm = new AboutUsInterFirm();aboutusinterfirm.setVisible(true);table.add(aboutusinterfirm);}});mnNewMenu_1.add(mntmNewMenuItem);contentPane = new JPanel();contentPane.setBackground(new Color(255, 255, 255));contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));setContentPane(contentPane);contentPane.setLayout(new BorderLayout(0,0));table = new JDesktopPane();contentPane.add(table,BorderLayout.CENTER);JLabel lblNewLabel = new JLabel("");lblNewLabel.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\mf-bg.jpg"));lblNewLabel.setBounds(10, 0, 1532, 717);table.add(lblNewLabel);//運行設置JFrame最大化:this.setExtendedState(JFrame.MAXIMIZED_BOTH);} }

5.關于菜品添加界面FoodAddInterFirm設計的代碼:

import java.awt.Color; import java.awt.EventQueue; import java.awt.Font; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.Connection; import java.sql.ResultSet;import javax.swing.GroupLayout; import javax.swing.GroupLayout.Alignment; import javax.swing.ImageIcon; import javax.swing.JButton; import javax.swing.JComboBox; import javax.swing.JInternalFrame; import javax.swing.JLabel; import javax.swing.JOptionPane; import javax.swing.JTextField; import javax.swing.LayoutStyle.ComponentPlacement; import javax.swing.border.LineBorder;import jdbc.dao.FoodDao; import jdbc.dao.FoodTypeDao; import jdbc.model.Food; import jdbc.model.FoodType; import jdbc.utils.JDBCtest; import jdbc.utils.StringUtil;public class FoodAddInterFirm extends JInternalFrame {private JTextField nameTXT;private JTextField storageTXT;private JTextField priceTXT;private JTextField descTXT;private JComboBox foodtypeCB;private JDBCtest jdbctest = new JDBCtest();private FoodTypeDao foodtypedao = new FoodTypeDao();private FoodDao fooddao = new FoodDao();/*** Launch the application.*/public static void main(String[] args) {EventQueue.invokeLater(new Runnable() {public void run() {try {FoodAddInterFirm frame = new FoodAddInterFirm();frame.setVisible(true);} catch (Exception e) {e.printStackTrace();}}});}/*** Create the frame.*/public FoodAddInterFirm() {getContentPane().setBackground(new Color(255, 99, 71));getContentPane().setForeground(new Color(255, 99, 71));setClosable(true);setIconifiable(true);setTitle("\u83DC\u54C1\u6DFB\u52A0");setBounds(100, 100, 607, 446);JLabel lblNewLabel = new JLabel("\u83DC\u54C1\u540D\u79F0\uFF1A");lblNewLabel.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u8FA3\u6912.png"));lblNewLabel.setForeground(new Color(255, 255, 255));lblNewLabel.setFont(new Font("等線 Light", Font.PLAIN, 16));nameTXT = new JTextField();nameTXT.setColumns(10);JLabel lblNewLabel_1 = new JLabel("\u83DC\u54C1\u50A8\u91CF\uFF1A");lblNewLabel_1.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u50A8\u91CF.png"));lblNewLabel_1.setForeground(new Color(255, 255, 255));lblNewLabel_1.setFont(new Font("等線 Light", Font.PLAIN, 16));storageTXT = new JTextField();storageTXT.setColumns(10);JLabel lblNewLabel_2 = new JLabel("\u83DC\u54C1\u552E\u4EF7\uFF1A");lblNewLabel_2.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u552E\u4EF7.png"));lblNewLabel_2.setForeground(new Color(255, 255, 255));lblNewLabel_2.setFont(new Font("等線 Light", Font.PLAIN, 16));priceTXT = new JTextField();priceTXT.setColumns(10);JLabel lblNewLabel_3 = new JLabel("\u83DC\u54C1\u63CF\u8FF0/\u5907\u6CE8\uFF1A");lblNewLabel_3.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u7F8E\u98DF.png"));lblNewLabel_3.setForeground(new Color(255, 255, 255));lblNewLabel_3.setFont(new Font("等線 Light", Font.PLAIN, 16));descTXT = new JTextField();descTXT.setColumns(10);//文本域加邊框:descTXT.setBorder(new LineBorder(new java.awt.Color(127,157,185),1,false));JButton btnNewButton = new JButton("\u6DFB\u52A0");btnNewButton.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u6DFB\u52A0.png"));btnNewButton.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {FoodAddActionPerformed(e);}});btnNewButton.setFont(new Font("等線 Light", Font.PLAIN, 16));JButton btnNewButton_1 = new JButton("\u91CD\u7F6E");btnNewButton_1.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u91CD\u7F6E.png"));btnNewButton_1.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {FoodResetActionPerformed(e);}});btnNewButton_1.setFont(new Font("等線 Light", Font.PLAIN, 16));JLabel lblNewLabel_4 = new JLabel("\u83DC\u54C1\u7C7B\u522B\uFF1A");lblNewLabel_4.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7C7B\u522B.png"));lblNewLabel_4.setForeground(new Color(255, 255, 255));lblNewLabel_4.setFont(new Font("等線 Light", Font.PLAIN, 16));foodtypeCB = new JComboBox();foodtypeCB.setBackground(new Color(211, 211, 211));GroupLayout groupLayout = new GroupLayout(getContentPane());groupLayout.setHorizontalGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGap(105).addComponent(btnNewButton, GroupLayout.PREFERRED_SIZE, 97, GroupLayout.PREFERRED_SIZE).addPreferredGap(ComponentPlacement.RELATED, 174, Short.MAX_VALUE).addComponent(btnNewButton_1, GroupLayout.PREFERRED_SIZE, 97, GroupLayout.PREFERRED_SIZE).addGap(130)).addGroup(groupLayout.createSequentialGroup().addGap(50).addGroup(groupLayout.createParallelGroup(Alignment.LEADING).addComponent(descTXT, GroupLayout.PREFERRED_SIZE, 475, GroupLayout.PREFERRED_SIZE).addGroup(groupLayout.createSequentialGroup().addGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGroup(groupLayout.createParallelGroup(Alignment.LEADING).addComponent(lblNewLabel_2, GroupLayout.DEFAULT_SIZE, 105, Short.MAX_VALUE).addComponent(lblNewLabel_1).addComponent(lblNewLabel_4, GroupLayout.PREFERRED_SIZE, 119, GroupLayout.PREFERRED_SIZE)).addPreferredGap(ComponentPlacement.RELATED)).addGroup(groupLayout.createSequentialGroup().addPreferredGap(ComponentPlacement.RELATED).addComponent(lblNewLabel).addGap(22))).addGroup(groupLayout.createParallelGroup(Alignment.LEADING).addComponent(nameTXT, GroupLayout.DEFAULT_SIZE, 142, Short.MAX_VALUE).addComponent(foodtypeCB, 0, 142, Short.MAX_VALUE).addComponent(priceTXT, GroupLayout.DEFAULT_SIZE, 142, Short.MAX_VALUE).addComponent(storageTXT, 142, 142, Short.MAX_VALUE)).addGap(222)).addComponent(lblNewLabel_3, GroupLayout.PREFERRED_SIZE, 165, GroupLayout.PREFERRED_SIZE)).addGap(70)));groupLayout.setVerticalGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGap(40).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(lblNewLabel).addComponent(nameTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addGap(18).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(lblNewLabel_1).addComponent(storageTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addGap(18).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(priceTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE).addComponent(lblNewLabel_2)).addGap(18).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(lblNewLabel_4).addComponent(foodtypeCB, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addPreferredGap(ComponentPlacement.UNRELATED).addComponent(lblNewLabel_3, GroupLayout.PREFERRED_SIZE, 26, GroupLayout.PREFERRED_SIZE).addGap(14).addComponent(descTXT, GroupLayout.PREFERRED_SIZE, 86, GroupLayout.PREFERRED_SIZE).addGap(32).addGroup(groupLayout.createParallelGroup(Alignment.BASELINE).addComponent(btnNewButton).addComponent(btnNewButton_1)).addContainerGap(44, Short.MAX_VALUE)));getContentPane().setLayout(groupLayout);//初始化下拉框:fillFoodType();}//重置事件處理:private void FoodResetActionPerformed(ActionEvent evt) {// TODO Auto-generated method stubresetValue();}//菜品添加事件處理:private void FoodAddActionPerformed(ActionEvent evt) {// TODO Auto-generated method stubString name = this.nameTXT.getText();String storage = this.storageTXT.getText();String price = this.priceTXT.getText();String desc = this.descTXT.getText();if(StringUtil.isEmpty(name)) {JOptionPane.showMessageDialog(null, "菜品名稱不能為空!!");return;}if(StringUtil.isEmpty(storage)) {JOptionPane.showMessageDialog(null, "菜品儲備不能為空!!");return;}if(StringUtil.isEmpty(price)) {JOptionPane.showMessageDialog(null, "菜品售價不能為空!!");return;}FoodType foodtype = (FoodType)foodtypeCB.getSelectedItem();int foodtype_id = foodtype.getFoodtype_id();Connection conn = null;try {Food food = new Food(name,Integer.parseInt(storage),Float.parseFloat(price),foodtype_id,desc);conn = jdbctest.getCon();int addNUM = fooddao.add(conn, food);if(addNUM == 1) {JOptionPane.showMessageDialog(null, "菜品添加成功!!");resetValue();}else {JOptionPane.showMessageDialog(null, "菜品添加失敗!!");}}catch(Exception e) {e.printStackTrace();JOptionPane.showMessageDialog(null, "菜品添加失敗!!");}finally {try {jdbctest.closeCon(conn);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}//清空表單private void resetValue() {this.nameTXT.setText("");this.storageTXT.setText("");this.priceTXT.setText("");this.descTXT.setText("");//關于菜品類別有:當沒有類別時的處理if(this.foodtypeCB.getItemCount()>0) {this.foodtypeCB.setSelectedIndex(0);}}//初始化菜品類別下拉框:private void fillFoodType() {Connection conn = null;FoodType foodtype = null;try {conn = jdbctest.getCon();ResultSet rs = foodtypedao.list(conn, new FoodType());while(rs.next()) {foodtype = new FoodType();foodtype.setFoodtype_id(rs.getInt("foodtype_id"));foodtype.setFoodtype_name(rs.getString("foodtype_name"));//需要對方法進行重寫:this.foodtypeCB.addItem(foodtype);//不直接將字符串傳進去是因為傳一個對象進去可以獲得對應的ID}}catch(Exception e) {e.printStackTrace();}finally {try {jdbctest.closeCon(conn);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}} }

6.關于菜品信息管理界面FoodManageInterFirm設計的代碼:

import java.awt.EventQueue; import java.awt.Font; import java.sql.Connection; import java.sql.ResultSet; import java.util.Vector;import javax.swing.GroupLayout; import javax.swing.GroupLayout.Alignment; import javax.swing.JButton; import javax.swing.JComboBox; import javax.swing.JInternalFrame; import javax.swing.JLabel; import javax.swing.JOptionPane; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.LayoutStyle.ComponentPlacement; import javax.swing.border.LineBorder; import javax.swing.border.TitledBorder; import javax.swing.table.DefaultTableModel;import jdbc.dao.FoodDao; import jdbc.dao.FoodTypeDao; import jdbc.model.Food; import jdbc.model.FoodType; import jdbc.utils.JDBCtest; import jdbc.utils.StringUtil;import java.awt.event.ActionListener; import java.awt.event.ActionEvent; import java.awt.Color; import javax.swing.ImageIcon; import javax.swing.JTextArea; import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent;public class FoodManageInterFirm extends JInternalFrame {private JTable foodtable;private JTextField s_nameTXT;private JComboBox s_typeCB;private JTextArea fooddescTXT;private JComboBox foodtypeCB;private JDBCtest jdbctest = new JDBCtest();private FoodTypeDao foodtypedao = new FoodTypeDao();private FoodDao fooddao = new FoodDao();private JTextField foodidTXT;private JTextField foodnameTXT;private JTextField foodstorageTXT;private JTextField foodpriceTXT;/*** Launch the application.*/public static void main(String[] args) {EventQueue.invokeLater(new Runnable() {public void run() {try {FoodManageInterFirm frame = new FoodManageInterFirm();frame.setVisible(true);} catch (Exception e) {e.printStackTrace();}}});}/*** Create the frame.*/public FoodManageInterFirm() {getContentPane().setBackground(new Color(255, 99, 71));setIconifiable(true);setClosable(true);setTitle("\u83DC\u54C1\u7BA1\u7406");setBounds(100, 100, 674, 570);JScrollPane scrollPane = new JScrollPane();JPanel panel = new JPanel();panel.setForeground(new Color(255, 255, 255));panel.setBackground(new Color(255, 99, 71));panel.setBorder(new TitledBorder(null, "\u641C\u7D22\u6761\u4EF6", TitledBorder.LEADING, TitledBorder.TOP, null, null));JPanel panel_1 = new JPanel();panel_1.setBackground(new Color(255, 99, 71));panel_1.setBorder(new TitledBorder(null, "\u8868\u5355\u64CD\u4F5C", TitledBorder.LEADING, TitledBorder.TOP, null, null));GroupLayout groupLayout = new GroupLayout(getContentPane());groupLayout.setHorizontalGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGap(21).addGroup(groupLayout.createParallelGroup(Alignment.TRAILING, false).addComponent(panel_1, Alignment.LEADING, 0, 0, Short.MAX_VALUE).addComponent(panel, Alignment.LEADING, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE).addComponent(scrollPane, Alignment.LEADING, GroupLayout.DEFAULT_SIZE, 628, Short.MAX_VALUE)).addGap(44)));groupLayout.setVerticalGroup(groupLayout.createParallelGroup(Alignment.LEADING).addGroup(groupLayout.createSequentialGroup().addGap(25).addComponent(panel, GroupLayout.PREFERRED_SIZE, 60, GroupLayout.PREFERRED_SIZE).addPreferredGap(ComponentPlacement.RELATED).addComponent(scrollPane, GroupLayout.PREFERRED_SIZE, 169, GroupLayout.PREFERRED_SIZE).addGap(18).addComponent(panel_1, GroupLayout.DEFAULT_SIZE, 198, Short.MAX_VALUE).addContainerGap()));JLabel lblNewLabel_2 = new JLabel("\u83DC\u54C1\u7F16\u53F7\uFF1A");lblNewLabel_2.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u7F16\u53F7.png"));lblNewLabel_2.setForeground(new Color(255, 255, 255));lblNewLabel_2.setFont(new Font("等線 Light", Font.PLAIN, 16));foodidTXT = new JTextField();foodidTXT.setEditable(false);foodidTXT.setColumns(10);JLabel lblNewLabel_3 = new JLabel("\u83DC\u54C1\u540D\u79F0\uFF1A");lblNewLabel_3.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u8FA3\u6912.png"));lblNewLabel_3.setForeground(new Color(255, 255, 255));lblNewLabel_3.setFont(new Font("等線 Light", Font.PLAIN, 16));foodnameTXT = new JTextField();foodnameTXT.setColumns(10);JLabel lblNewLabel_4 = new JLabel("\u83DC\u54C1\u50A8\u5907\uFF1A");lblNewLabel_4.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u50A8\u91CF.png"));lblNewLabel_4.setFont(new Font("等線 Light", Font.PLAIN, 16));lblNewLabel_4.setForeground(new Color(255, 255, 255));foodstorageTXT = new JTextField();foodstorageTXT.setColumns(10);JLabel lblNewLabel_5 = new JLabel("\u83DC\u54C1\u552E\u4EF7\uFF1A");lblNewLabel_5.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u552E\u4EF7.png"));lblNewLabel_5.setForeground(new Color(255, 255, 255));lblNewLabel_5.setFont(new Font("等線 Light", Font.PLAIN, 16));foodpriceTXT = new JTextField();foodpriceTXT.setColumns(10);JLabel lblNewLabel_6 = new JLabel("\u83DC\u54C1\u7C7B\u522B\uFF1A");lblNewLabel_6.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7C7B\u522B.png"));lblNewLabel_6.setForeground(new Color(255, 255, 255));lblNewLabel_6.setFont(new Font("等線 Light", Font.PLAIN, 16));foodtypeCB = new JComboBox();JLabel lblNewLabel_7 = new JLabel("\u83DC\u54C1\u63CF\u8FF0\uFF1A");lblNewLabel_7.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u7F8E\u98DF.png"));lblNewLabel_7.setForeground(new Color(255, 255, 255));lblNewLabel_7.setFont(new Font("等線 Light", Font.PLAIN, 16));fooddescTXT = new JTextArea();//文本域加邊框:fooddescTXT.setBorder(new LineBorder(new java.awt.Color(127,157,185),1,false));JButton btnNewButton_1 = new JButton("\u4FEE\u6539");btnNewButton_1.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {foodUpdateActionPerformed(e);}});btnNewButton_1.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u4FEE\u6539.png"));btnNewButton_1.setFont(new Font("等線 Light", Font.PLAIN, 16));JButton btnNewButton_2 = new JButton("\u5220\u9664");btnNewButton_2.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {foodDeleteActionPerformed(e);}});btnNewButton_2.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u5220\u96642.png"));btnNewButton_2.setForeground(new Color(0, 0, 0));btnNewButton_2.setFont(new Font("等線 Light", Font.PLAIN, 16));GroupLayout gl_panel_1 = new GroupLayout(panel_1);gl_panel_1.setHorizontalGroup(gl_panel_1.createParallelGroup(Alignment.LEADING).addGroup(gl_panel_1.createSequentialGroup().addContainerGap().addGroup(gl_panel_1.createParallelGroup(Alignment.TRAILING, false).addComponent(lblNewLabel_7, Alignment.LEADING, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE).addComponent(lblNewLabel_5, Alignment.LEADING, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE).addComponent(lblNewLabel_2, Alignment.LEADING, GroupLayout.PREFERRED_SIZE, 82, Short.MAX_VALUE)).addPreferredGap(ComponentPlacement.RELATED).addGroup(gl_panel_1.createParallelGroup(Alignment.LEADING).addGroup(Alignment.TRAILING, gl_panel_1.createSequentialGroup().addComponent(btnNewButton_1, GroupLayout.PREFERRED_SIZE, 97, GroupLayout.PREFERRED_SIZE).addPreferredGap(ComponentPlacement.RELATED, 218, Short.MAX_VALUE).addComponent(btnNewButton_2, GroupLayout.PREFERRED_SIZE, 97, GroupLayout.PREFERRED_SIZE).addGap(175)).addGroup(gl_panel_1.createSequentialGroup().addGroup(gl_panel_1.createParallelGroup(Alignment.TRAILING).addGroup(gl_panel_1.createSequentialGroup().addGroup(gl_panel_1.createParallelGroup(Alignment.LEADING).addGroup(gl_panel_1.createSequentialGroup().addComponent(foodidTXT, GroupLayout.PREFERRED_SIZE, 53, GroupLayout.PREFERRED_SIZE).addGap(31).addComponent(lblNewLabel_3)).addComponent(foodpriceTXT, GroupLayout.PREFERRED_SIZE, 115, GroupLayout.PREFERRED_SIZE)).addPreferredGap(ComponentPlacement.RELATED).addGroup(gl_panel_1.createParallelGroup(Alignment.LEADING).addGroup(gl_panel_1.createSequentialGroup().addComponent(lblNewLabel_6).addPreferredGap(ComponentPlacement.RELATED).addComponent(foodtypeCB, GroupLayout.PREFERRED_SIZE, 91, GroupLayout.PREFERRED_SIZE)).addGroup(gl_panel_1.createSequentialGroup().addComponent(foodnameTXT, GroupLayout.PREFERRED_SIZE, 98, GroupLayout.PREFERRED_SIZE).addGap(18).addComponent(lblNewLabel_4).addPreferredGap(ComponentPlacement.RELATED).addComponent(foodstorageTXT, GroupLayout.DEFAULT_SIZE, 65, Short.MAX_VALUE)))).addComponent(fooddescTXT, Alignment.LEADING, GroupLayout.PREFERRED_SIZE, 483, GroupLayout.PREFERRED_SIZE)).addGap(104)))));gl_panel_1.setVerticalGroup(gl_panel_1.createParallelGroup(Alignment.LEADING).addGroup(gl_panel_1.createSequentialGroup().addGroup(gl_panel_1.createParallelGroup(Alignment.BASELINE).addComponent(lblNewLabel_2, GroupLayout.PREFERRED_SIZE, 29, GroupLayout.PREFERRED_SIZE).addComponent(foodidTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE).addComponent(lblNewLabel_3, GroupLayout.PREFERRED_SIZE, 23, GroupLayout.PREFERRED_SIZE).addComponent(foodnameTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE).addComponent(lblNewLabel_4, GroupLayout.PREFERRED_SIZE, 23, GroupLayout.PREFERRED_SIZE).addComponent(foodstorageTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addPreferredGap(ComponentPlacement.UNRELATED).addGroup(gl_panel_1.createParallelGroup(Alignment.BASELINE).addComponent(lblNewLabel_5).addComponent(foodpriceTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE).addComponent(lblNewLabel_6).addComponent(foodtypeCB, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)).addPreferredGap(ComponentPlacement.UNRELATED).addGroup(gl_panel_1.createParallelGroup(Alignment.LEADING).addComponent(lblNewLabel_7).addComponent(fooddescTXT, GroupLayout.PREFERRED_SIZE, 48, GroupLayout.PREFERRED_SIZE)).addGap(40).addGroup(gl_panel_1.createParallelGroup(Alignment.BASELINE).addComponent(btnNewButton_2).addComponent(btnNewButton_1)).addContainerGap(43, Short.MAX_VALUE)));panel_1.setLayout(gl_panel_1);JLabel lblNewLabel = new JLabel("\u83DC\u54C1\u540D\u79F0\uFF1A");lblNewLabel.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u8FA3\u6912.png"));lblNewLabel.setForeground(new Color(255, 255, 255));lblNewLabel.setFont(new Font("等線 Light", Font.PLAIN, 16));s_nameTXT = new JTextField();s_nameTXT.setColumns(10);JLabel lblNewLabel_1 = new JLabel("\u83DC\u54C1\u7C7B\u522B\uFF1A");lblNewLabel_1.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u83DC\u54C1\u7C7B\u522B.png"));lblNewLabel_1.setForeground(new Color(255, 255, 255));lblNewLabel_1.setFont(new Font("等線 Light", Font.PLAIN, 16));s_typeCB = new JComboBox();JButton btnNewButton = new JButton("\u67E5\u8BE2");btnNewButton.setIcon(new ImageIcon("C:\\Users\\86135\\eclipse-workspace\\ResturantOrder\\src\\images\\\u67E5\u8BE2.png"));btnNewButton.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {FoodSearchActionPerformed(e);}});btnNewButton.setFont(new Font("等線 Light", Font.PLAIN, 16));GroupLayout gl_panel = new GroupLayout(panel);gl_panel.setHorizontalGroup(gl_panel.createParallelGroup(Alignment.LEADING).addGroup(gl_panel.createSequentialGroup().addContainerGap().addComponent(lblNewLabel).addPreferredGap(ComponentPlacement.RELATED).addComponent(s_nameTXT, GroupLayout.PREFERRED_SIZE, 90, GroupLayout.PREFERRED_SIZE).addGap(18).addComponent(lblNewLabel_1).addPreferredGap(ComponentPlacement.RELATED).addComponent(s_typeCB, GroupLayout.PREFERRED_SIZE, 97, GroupLayout.PREFERRED_SIZE).addPreferredGap(ComponentPlacement.RELATED, 15, Short.MAX_VALUE).addComponent(btnNewButton, GroupLayout.PREFERRED_SIZE, 97, GroupLayout.PREFERRED_SIZE).addContainerGap()));gl_panel.setVerticalGroup(gl_panel.createParallelGroup(Alignment.LEADING).addGroup(gl_panel.createSequentialGroup().addGroup(gl_panel.createParallelGroup(Alignment.BASELINE).addComponent(lblNewLabel, GroupLayout.DEFAULT_SIZE, 23, Short.MAX_VALUE).addComponent(s_nameTXT, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE).addComponent(lblNewLabel_1).addComponent(s_typeCB, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE).addComponent(btnNewButton)).addContainerGap()));panel.setLayout(gl_panel);foodtable = new JTable();foodtable.addMouseListener(new MouseAdapter() {@Overridepublic void mousePressed(MouseEvent me) {foodTableMousePressed(me);}});foodtable.setFont(new Font("等線 Light", Font.PLAIN, 14));foodtable.setModel(new DefaultTableModel(new Object[][] {},new String[] {"\u83DC\u54C1\u7F16\u53F7", "\u83DC\u54C1\u540D\u79F0", "\u83DC\u54C1\u50A8\u5907", "\u83DC\u54C1\u552E\u4EF7", "\u83DC\u54C1\u7C7B\u522B\u7F16\u53F7", "\u83DC\u54C1\u63CF\u8FF0", "\u83DC\u54C1\u7C7B\u522B\u540D\u79F0"}));foodtable.getColumnModel().getColumn(0).setPreferredWidth(63);foodtable.getColumnModel().getColumn(1).setPreferredWidth(61);foodtable.getColumnModel().getColumn(2).setPreferredWidth(59);foodtable.getColumnModel().getColumn(3).setPreferredWidth(61);foodtable.getColumnModel().getColumn(4).setPreferredWidth(86);foodtable.getColumnModel().getColumn(6).setPreferredWidth(84);scrollPane.setViewportView(foodtable);getContentPane().setLayout(groupLayout);this.fillFoodType("search");this.fillFoodType("modify");this.fillTable(new Food());}//菜品刪除事件處理private void foodDeleteActionPerformed(ActionEvent evt) {// TODO Auto-generated method stubString id = foodidTXT.getText();if(StringUtil.isEmpty(id)) {JOptionPane.showMessageDialog(null, "請選擇要刪除的記錄!!");return;}int n = JOptionPane.showConfirmDialog(null, "確定要刪除該記錄嗎?");if( n == 0) {Connection conn = null;try {conn = JDBCtest.getCon();int deleteNUM = fooddao.delete(conn, id);//JOptionPane.showMessageDialog(null, deleteNUM);if(deleteNUM != 0) {JOptionPane.showMessageDialog(null, "刪除成功!!");this.resetValue();this.fillTable(new Food());}else {JOptionPane.showMessageDialog(null, "刪除失敗!!");}}catch(Exception e) {e.printStackTrace();JOptionPane.showMessageDialog(null, "刪除失敗!!");}finally {try {JDBCtest.closeCon(conn);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}}//修改菜品信息事件處理:private void foodUpdateActionPerformed(ActionEvent evt) {// TODO Auto-generated method stubString name = this.foodnameTXT.getText();String storage = this.foodstorageTXT.getText();String price = this.foodpriceTXT.getText();String desc = this.fooddescTXT.getText();String id = this.foodidTXT.getText();if(StringUtil.isEmpty(id)) {JOptionPane.showMessageDialog(null, "請選擇要修改的記錄!!");return;}if(StringUtil.isEmpty(storage)) {JOptionPane.showMessageDialog(null, "菜品儲備不能為空!!");return;}if(StringUtil.isEmpty(price)) {JOptionPane.showMessageDialog(null, "菜品售價不能為空!!");return;}if(StringUtil.isEmpty(name)) {JOptionPane.showMessageDialog(null, "菜品名稱不能為空!!");return;}FoodType foodtype = (FoodType)foodtypeCB.getSelectedItem();int typeid = foodtype.getFoodtype_id();Food food = new Food(Integer.parseInt(id),name,Integer.parseInt(storage),Float.parseFloat(price),typeid,desc);Connection conn = null;try {conn = jdbctest.getCon();int addNUM = fooddao.update(conn, food);if(addNUM == 1) {JOptionPane.showMessageDialog(null, "菜品修改成功!!");resetValue();this.fillTable(new Food());}else {JOptionPane.showMessageDialog(null, "菜品修改失敗!!");}}catch(Exception e) {e.printStackTrace();JOptionPane.showMessageDialog(null, "菜品修改失敗!!");}finally {try {jdbctest.closeCon(conn);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}//重置表單事件:private void resetValue() {// TODO Auto-generated method stubthis.foodidTXT.setText("");this.foodnameTXT.setText("");this.foodstorageTXT.setText("");this.foodpriceTXT.setText("");this.fooddescTXT.setText("");//關于菜品類別有:當沒有類別時的處理if(this.foodtypeCB.getItemCount()>0) {this.foodtypeCB.setSelectedIndex(0);}}//表格行的鼠標點擊事件處理:private void foodTableMousePressed(MouseEvent me) {// TODO Auto-generated method stubint row = this.foodtable.getSelectedRow();this.foodidTXT.setText((String)foodtable.getValueAt(row, 0));this.foodnameTXT.setText((String)foodtable.getValueAt(row, 1));this.foodstorageTXT.setText((String)foodtable.getValueAt(row, 2));this.foodpriceTXT.setText((String)foodtable.getValueAt(row, 3));this.fooddescTXT.setText((String)foodtable.getValueAt(row, 5));String foodtypename = (String)this.foodtable.getValueAt(row, 6);int n = this.foodtypeCB.getItemCount();for(int i=0;i<n;i++) {FoodType item = (FoodType)this.foodtypeCB.getItemAt(i);if(item.getFoodtype_name().equals(foodtypename)) {this.foodtypeCB.setSelectedIndex(i);}}}//菜品搜索查詢事件處理:private void FoodSearchActionPerformed(ActionEvent evt) {// TODO Auto-generated method stubString foodname = s_nameTXT.getText();FoodType foodtype = (FoodType) this.s_typeCB.getSelectedItem();int foodtypeid = foodtype.getFoodtype_id();Food food = new Food(foodname,foodtypeid);this.fillTable(food);}//填充一個下拉框:private void fillFoodType(String type) {Connection conn = null;try {conn = jdbctest.getCon();ResultSet rs = foodtypedao.list(conn, new FoodType());if("search".equals(type)) {FoodType foodtype = new FoodType();foodtype.setFoodtype_name("請選擇...");foodtype.setFoodtype_id(-1);this.s_typeCB.addItem(foodtype);}while(rs.next()) {FoodType foodtype = new FoodType();foodtype.setFoodtype_name(rs.getString("foodtype_name"));foodtype.setFoodtype_id(rs.getInt("foodtype_id"));//分兩種情況:if("search".equals(type)) {this.s_typeCB.addItem(foodtype);}else if("modify".equals(type)) {this.foodtypeCB.addItem(foodtype);}}}catch(Exception e) {e.printStackTrace();}finally {try {jdbctest.closeCon(conn);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}//初始化表格數據:private void fillTable(Food food) {//初始化:清空表格DefaultTableModel dtm =(DefaultTableModel) foodtable.getModel();//表格設置成0行:dtm.setRowCount(0);Connection conn = null;try {conn = jdbctest.getCon();ResultSet rs = fooddao.list(conn, food);while(rs.next()) {Vector v = new Vector();v.add(rs.getString("food_id"));v.add(rs.getString("food_name"));v.add(rs.getString("food_storage"));v.add(rs.getString("food_price"));v.add(rs.getString("food_typeid"));v.add(rs.getString("food_desc"));v.add(rs.getString("foodtype_name"));dtm.addRow(v);}}catch(Exception e) {e.printStackTrace();}finally {try {jdbctest.closeCon(conn);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}} }

總結

以上是生活随笔為你收集整理的西工大数据库实验大作业 火锅店菜品管理系统的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

天天亚洲 | 9999免费视频 | 国产精品一区二区在线免费观看 | 亚洲精品电影在线 | 又爽又黄又无遮挡网站动态图 | 五月开心婷婷 | 精品视频在线视频 | 国产亚洲无 | 国产成人精品一区二区三区在线观看 | 久久伦理网 | 亚洲h色精品 | 亚洲国产欧美一区二区三区丁香婷 | 在线日本看片免费人成视久网 | 国产精品手机在线观看 | 免费观看福利视频 | 久久综合九色综合欧美就去吻 | 亚洲第二色 | 久久婷婷国产色一区二区三区 | 丝袜精品视频 | 国产精品国内免费一区二区三区 | 久久精品爱视频 | 欧美成人h版电影 | 精品国产欧美一区二区三区不卡 | 在线之家免费在线观看电影 | 久久久久综合精品福利啪啪 | 最新高清无码专区 | 99情趣网视频 | 我要看黄色一级片 | 成人性生交大片免费看中文网站 | 成年人精品 | 免费黄色av电影 | 亚洲一级国产 | 青青草国产精品 | 久久成 | 丁香久久五月 | 欧美在线观看小视频 | 激情久久五月 | 五月天亚洲精品 | 国产精品99久久久 | 天天综合网 天天 | 91漂亮少妇露脸在线播放 | 久草国产精品 | 免费在线观看91 | 亚洲综合在线五月 | 欧洲精品视频一区二区 | 亚洲一二三区精品 | 色婷婷免费 | 十八岁以下禁止观看的1000个网站 | 久久99热精品这里久久精品 | 日本精品一区二区 | 亚洲综合在线一区二区三区 | 国产剧情一区二区在线观看 | 日韩专区一区二区 | 波多野结衣在线观看一区二区三区 | 五月天综合色 | 99r在线播放 | 欧美一区日韩一区 | 国产精品久久网站 | av中文字幕电影 | 中文字幕中文字幕在线中文字幕三区 | 99麻豆视频 | 久草在线| 日本中文字幕在线 | 99这里只有久久精品视频 | 国产精品久久一区二区三区不卡 | 久久99精品国产一区二区三区 | 91成人在线免费观看 | 国产黄a三级三级 | 日本精品视频一区 | 激情六月婷婷久久 | 国产精品免费在线播放 | 九九在线免费视频 | 日韩精品一区二区久久 | 亚洲 欧洲av | 美女国内精品自产拍在线播放 | 久久免费成人精品视频 | 99在线免费观看视频 | 国产在线播放不卡 | 人人天天夜夜 | 欧美日本三级 | 91视频在线免费观看 | www.国产毛片 | 亚洲一区二区黄色 | 天天曰视频 | 欧美性生活一级片 | 亚洲精选99 | 国产精品第三页 | 久久久久欠精品国产毛片国产毛生 | 欧美一区二区日韩一区二区 | 欧美视频网址 | 日韩精品中文字幕有码 | 欧洲精品视频一区二区 | 国产美女视频免费观看的网站 | 在线观看视频在线 | 国产精品一区二区三区99 | 国产精品一区久久久久 | 色婷婷狠狠五月综合天色拍 | 国产免费叼嘿网站免费 | 国产精品久久一卡二卡 | av一区二区三区在线观看 | 久久久久久亚洲精品 | 一区二区三区电影在线播 | 国产激情电影综合在线看 | 精品久久久久久久久中文字幕 | 精品国产电影一区 | 国产精品九九九九九九 | 国产高清在线一区 | 国产精品夜夜夜一区二区三区尤 | 亚洲国产日韩在线 | 在线观看国产www | 婷婷久久亚洲 | 久久超级碰 | 色吊丝在线永久观看最新版本 | 国产 欧美 在线 | 日韩特黄av| 国产精品自拍在线 | 伊人久久婷婷 | 五月婷婷丁香在线观看 | 九九国产精品视频 | 夜夜摸夜夜爽 | 激情网五月婷婷 | 日韩电影在线看 | 国产精品毛片久久蜜 | 中文字幕在线观看第三页 | 成人一区二区在线 | 有码中文在线 | 国产高清不卡在线 | 五月婷婷欧美视频 | 国产精品一区专区欧美日韩 | 亚洲精品乱码久久 | 成人免费在线看片 | 国产日产亚洲精华av | 亚洲第一中文字幕 | 激情丁香| 在线看小早川怜子av | 久久精品影视 | 国产露脸91国语对白 | 丁香婷婷在线观看 | 四虎影视精品成人 | 中文字幕有码在线 | 欧美成人h版电影 | 国产破处在线播放 | 插综合网 | 丁香花在线观看免费完整版视频 | 国产精品久久久久久模特 | 国产在线一卡 | 四虎在线免费观看 | 久久综合狠狠综合久久狠狠色综合 | 中文一区二区三区在线观看 | 国产精品美女视频网站 | 免费在线国产精品 | 亚洲精品理论 | 国产视频亚洲 | 日日射天天射 | 国产精品一区二区果冻传媒 | 国产99久久久欧美黑人 | 天堂av在线免费观看 | 91欧美国产 | 久久久久久久久久久高潮一区二区 | 在线观看日韩视频 | 国产午夜精品一区二区三区嫩草 | 一区二区不卡高清 | 久久99国产视频 | 国产精品视频地址 | 午夜精品久久久久久久99水蜜桃 | 国产黄色免费在线观看 | 天天干天天弄 | 婷婷激情在线观看 | 国产一级片一区二区三区 | 国产高清免费 | 国产色影院 | 精品国产精品久久 | 超碰在线观看av.com | 91av视频网站 | 中文视频在线 | 国产不卡av在线 | 麻豆国产网站 | 国产91精品一区二区绿帽 | 大片网站久久 | 欧美一区二区三区四区夜夜大片 | 亚洲资源一区 | 激情五月婷婷网 | 国产精品免费一区二区三区在线观看 | 在线观看日韩一区 | 久久天天拍 | 亚洲播放一区 | www激情com | 成年美女黄网站色大片免费看 | 97超碰伊人 | 日韩欧美电影网 | av免费片 | 亚州精品国产 | 在线视频你懂得 | 欧美一级性生活视频 | 日本最大色倩网站www | 97超级碰 | 国产成人99久久亚洲综合精品 | 在线观看免费国产小视频 | 在线看v片| 91黄色在线视频 | h视频日本 | 在线看国产视频 | av在线一二三区 | 丁香婷婷色月天 | 久久精品亚洲一区二区三区观看模式 | 99精品视频播放 | 精品一区在线看 | 天天天天天天天天操 | 安徽妇搡bbbb搡bbbb | 天堂在线免费视频 | 毛片在线网 | 中国美女一级看片 | 99免费在线播放99久久免费 | 天天躁天天躁天天躁婷 | 性色av免费在线观看 | 在线播放 日韩专区 | 久久久久久久久久久久99 | 在线黄色av | 国产99久久久国产精品免费看 | 久久久久久久久免费 | 伊人久久五月天 | 国产精品一区久久久久 | 免费性网站 | 中文字幕精品一区久久久久 | 人人搞人人爽 | 免费在线观看av | 国产高清中文字幕 | 国内精品免费 | 国产高清成人 | 特级西西444www大胆高清无视频 | 69夜色精品国产69乱 | 一区二区精品在线观看 | 在线观看中文字幕亚洲 | 精品久久久久久久久久久院品网 | 国产精品久久久久久久av电影 | 欧美夫妻性生活电影 | 国产一区在线视频 | 国产午夜精品一区二区三区 | 日日天天 | 粉嫩av一区二区三区四区 | 9热精品| 日韩有码在线观看视频 | 97超碰人人澡 | 亚洲电影毛片 | 日韩精品免费一线在线观看 | www.久久婷婷 | 色99中文字幕 | 中文字幕4| 中文国产在线观看 | 日韩免费在线播放 | 国产黄色精品网站 | 日韩黄视频| 91亚洲成人 | 成年人在线观看网站 | 福利网址在线观看 | 欧美日韩一级久久久久久免费看 | 国产色女 | 日日碰狠狠躁久久躁综合网 | 日韩系列 | 国产乱码精品一区二区三区介绍 | 久久美女免费视频 | 91麻豆福利 | 超碰在线网 | 91一区啪爱嗯打偷拍欧美 | 国产69精品久久久久久 | 国产精品九九九九九 | 黄色成人91 | 黄视频色网站 | 丁香婷婷激情网 | 成人精品一区二区三区中文字幕 | 亚洲精品在线免费看 | 精品视频久久久久久 | 日本超碰在线 | 久久久久久久影院 | 国内一区二区视频 | 久久国产精品久久w女人spa | 成人av一区二区在线观看 | 精品美女久久久久久免费 | 国产日本在线观看 | 激情五月婷婷综合 | 在线播放国产一区二区三区 | 三级av免费| 一区在线观看 | 国内精品久久久久久久久久久 | 伊人网综合在线观看 | 国产在线欧美在线 | 国产精品一区二区视频 | 六月色 | 日韩av电影手机在线观看 | 国产精品一区二区在线播放 | 99色99| 天天操伊人 | www.天天草 | 国产精品久久三 | 久久综合九色综合久久久精品综合 | 国产成人精品电影久久久 | 国产xxxx | 亚洲精选视频在线 | www.天天综合| 国内一区二区视频 | 在线观看视频你懂的 | 久久久久久久福利 | 最近中文字幕在线中文高清版 | 激情婷婷久久 | www.夜夜| 一区二区三区电影在线播 | 西西4444www大胆艺术 | 免费日韩 精品中文字幕视频在线 | 欧美精品在线免费 | 国产精品av免费在线观看 | 成人欧美一区二区三区黑人麻豆 | 国产精品一区二区久久精品爱微奶 | 91av短视频 | 在线黄色av电影 | 一区二区视频在线看 | 色综合久久久久久久 | 丁香婷婷激情网 | 丁香 婷婷 激情 | 成人精品亚洲 | 亚洲国产精品一区二区久久hs | 久久免费电影网 | 国产又粗又猛又黄又爽视频 | 在线播放av网址 | 五月天激情综合网 | 中文字幕最新精品 | 狠狠色丁香婷婷综合视频 | 99久热精品 | 国产在线探花 | 久久理论电影 | 九九九免费视频 | 91麻豆传媒 | 国产网红在线观看 | 久久人人爽人人爽人人片av软件 | 亚洲片在线资源 | 五月天综合网站 | 亚洲综合欧美日韩狠狠色 | 美女网站黄免费 | 日韩免费观看一区二区 | 欧美国产三区 | 亚洲丝袜中文 | 国产精品久久久久久久久费观看 | 中文字幕一区二区三区久久 | 国产精品一区免费观看 | 69av免费视频 | 久久国产美女视频 | 久热爱| 中文字幕在线播放第一页 | 亚洲国产99 | 亚洲v欧美v国产v在线观看 | 摸bbb搡bbb搡bbbb | 99免费在线观看 | 午夜电影一区 | 狠狠色丁香久久婷婷综 | 中文字幕一区三区 | 国产午夜一区 | www.97视频 | 97精品国产91久久久久久 | 亚洲综合在线观看视频 | 夜色.com | japanese黑人亚洲人4k | 久久精品一区二区三区中文字幕 | 人人爽爽人人 | 欧美日韩在线播放一区 | 久久久久久97三级 | 天天操天天干天天干 | 色姑娘综合| 国产精品观看视频 | 丁香婷婷激情五月 | 天天干天天操人体 | 久久在线观看 | 久久综合之合合综合久久 | 四虎成人精品永久免费av九九 | 欧美日韩裸体免费视频 | 少妇bbw撒尿| 五月婷婷六月综合 | 欧美人人 | 日本久久久久久久久久久 | 在线免费观看视频你懂的 | av片在线观看免费 | 在线观看国产91 | 人人干人人艹 | 中文字幕av免费在线观看 | 国产精品免费不卡 | 亚州视频在线 | 在线免费黄色av | 人人狠狠综合久久亚洲 | 麻豆视频在线观看免费 | 玖玖视频免费在线 | 日韩欧美久久 | 日韩欧美在线观看一区二区 | 五月婷婷激情五月 | 波多野结衣视频一区二区 | 亚洲精品国偷自产在线91正片 | 久久久久综合精品福利啪啪 | 激情五月在线视频 | 婷婷色综合 | 欧美日韩在线观看一区二区三区 | 超碰伊人网 | 在线播放视频一区 | 亚洲天堂网视频在线观看 | 91视频免费观看 | 久久精品国产免费看久久精品 | 黄色综合 | 在线a亚洲视频播放在线观看 | 成人av资源 | 在线观看亚洲a | 久艹在线播放 | 国产99久久精品一区二区永久免费 | 国产精品久久一区二区无卡 | 三级免费黄色 | 探花视频网站 | 欧美午夜寂寞影院 | 在线观看视频99 | 亚洲一二区视频 | 韩国av一区二区三区在线观看 | 欧美va天堂va视频va在线 | 免费在线黄色av | 国产精品s色 | a级一a一级在线观看 | 亚洲国产精品传媒在线观看 | 日韩视频免费在线 | 免费男女羞羞的视频网站中文字幕 | 特级片免费看 | 在线免费高清一区二区三区 | 国产中文字幕视频在线观看 | 午夜男人影院 | 精品久久久久久一区二区里番 | 欧美色久 | 91精品国产91热久久久做人人 | 麻豆精品视频在线观看免费 | 日韩特黄av | 亚洲日本精品 | 日韩中文字幕免费看 | 国产特黄色片 | 国产精品久久麻豆 | 国产尤物在线 | 欧洲在线免费视频 | 中文字幕高清有码 | 国产视频亚洲视频 | 一区二区不卡 | 免费手机黄色网址 | 一本一道久久a久久精品蜜桃 | 日日干夜夜骑 | 婷婷免费在线视频 | 五月综合网 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 五月开心色 | 在线观看中文字幕2021 | 日韩天堂在线观看 | 久久久久久蜜av免费网站 | av不卡免费在线观看 | 亚洲精品综合久久 | 超碰av在线免费观看 | 一区二区三区 亚洲 | 精品国产自 | 欧美黄色免费 | 久久久久激情电影 | 日韩激情精品 | 亚洲国产成人高清精品 | 天天做天天爱夜夜爽 | 丁香激情综合国产 | 在线国产日本 | 亚洲精品视频二区 | 天天曰天天爽 | 日韩在线观看网址 | 久久综合偷偷噜噜噜色 | 伊甸园av在线 | 东方av免费在线观看 | 国产精品丝袜 | 国产一区二区精品久久91 | 超碰97国产精品人人cao | 国产精品国产三级国产aⅴ无密码 | 久久精品视频免费播放 | 一本一本久久aa综合精品 | 日韩在线电影一区 | 中文字幕在线观看视频免费 | 国产最顶级的黄色片在线免费观看 | 国产视频色| 欧美黑人性猛交 | 九九热在线观看 | 亚洲激情校园春色 | 69欧美视频 | 国产日韩精品在线观看 | 日韩免费二区 | 欧美国产日韩激情 | 久久久久久久久久毛片 | 欧美日韩国产精品一区二区亚洲 | 综合影视 | 在线视频观看你懂的 | 91av电影在线 | www99久久 | 国产第页| 久草在线免费新视频 | 久久久久免费精品视频 | 国产视频精品久久 | 久久久国产精品一区二区三区 | 久久综合中文字幕 | 中文字幕在线播放第一页 | 一区二区精品久久 | 91精彩在线视频 | 久久免费公开视频 | 免费网址在线播放 | 狠狠88综合久久久久综合网 | 成人在线播放免费观看 | 丁香六月久久综合狠狠色 | 黄色一二级片 | 久久99热这里只有精品国产 | 亚洲国产精品久久久 | 中文字幕在线观看第二页 | 精品影院一区二区久久久 | 亚洲一级片 | 最近日本中文字幕a | 国产区久久 | 国产精品久久久久久五月尺 | 毛片无卡免费无播放器 | 精品一区三区 | 黄色网www| 五月天狠狠操 | 在线а√天堂中文官网 | 成人在线视 | 亚洲视频 一区 | 天堂网一区 | 成人国产电影在线观看 | 色偷偷88888欧美精品久久久 | 久久伦理网 | 欧美一级欧美一级 | 国产在线观看免费av | 国产在线日韩 | 久久一视频 | 国产伦精品一区二区三区无广告 | 亚洲更新最快 | 免费在线观看国产精品 | 又黄又爽又刺激视频 | 国产视频2区 | 99视频在线精品国自产拍免费观看 | 91精品国产欧美一区二区 | 97人人模人人爽人人少妇 | 天天操天天操天天爽 | 天天操综合网站 | 久久久久国产精品www | 操老逼免费视频 | 在线播放 一区 | 成人免费视频a | 九九视频精品免费 | 狠狠撸电影 | 精品国产伦一区二区三区观看体验 | 婷婷久久丁香 | 色五月成人 | 久草在线这里只有精品 | 国产午夜精品久久久久久久久久 | 欧美久久久久久久久久久久 | 999国内精品永久免费视频 | 九九99| 亚洲毛片视频 | 高清在线一区二区 | a在线免费观看视频 | 欧美精品在线观看免费 | 免费在线看v | 成人高清av在线 | 五月亚洲婷婷 | 国内久久看 | 久久论理| 久久免费a | 在线观看免费一级片 | 偷拍精偷拍精品欧洲亚洲网站 | 欧美二区在线播放 | 91高清不卡 | 日韩 在线a | 天天综合天天做 | 国产高清视频在线 | 久久久av电影 | 久久国产高清 | 欧亚日韩精品一区二区在线 | 在线播放91 | 在线观看色网站 | 97精品国产一二三产区 | 91成人在线看| 亚洲国产精品传媒在线观看 | 在线看欧美 | 中文字幕久久亚洲 | 黄色一集片 | 中文字幕资源网在线观看 | 成人在线一区二区三区 | 日韩高清精品一区二区 | 欧美在线91| 国产亚洲精品成人av久久影院 | 色999五月色 | 国产探花视频在线播放 | 久久午夜网 | 97小视频| 高潮久久久久久久久 | 亚洲精品视频在线观看网站 | 日韩欧美视频在线免费观看 | 国产国语在线 | 2019中文字幕网站 | 免费在线激情视频 | 久久五月婷婷丁香 | 亚州五月| 国产中文字幕在线播放 | 国产黄在线免费观看 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 亚洲一区二区三区毛片 | 欧美日韩视频一区二区三区 | 99久久精品国产欧美主题曲 | 日本精品在线看 | 国产不卡在线看 | 亚洲欧美激情精品一区二区 | 麻豆精品在线视频 | 99精品国产99久久久久久97 | 欧美激情综合色综合啪啪五月 | 久久久午夜视频 | 色在线观看网站 | 久久人人爽人人 | 久久久久久久久久久久久国产精品 | 精品91| 欧美黑吊大战白妞欧美 | 在线播放一区二区三区 | 亚洲成人一二三 | 91精品一区在线观看 | 操操操影院 | 亚州精品在线视频 | 久久99在线观看 | 日韩精品一区二区三区高清免费 | 91系列在线观看 | 国产在线精品一区二区三区 | 日韩在线观看不卡 | 中文字幕成人在线观看 | 97国产人人 | 国产片免费在线观看视频 | 香蕉视频国产在线 | 很黄很黄的网站免费的 | 亚洲黄色一级电影 | 亚洲视频在线看 | 婷婷在线综合 | 一区二区三区免费在线观看视频 | 国产一级免费av | 懂色av一区二区在线播放 | 中文字幕乱码亚洲精品一区 | 四虎在线观看视频 | 国产精品18久久久久久首页狼 | 欧美综合久久 | 免费看三级网站 | 91成人观看| 一区二区三区手机在线观看 | 日韩a级免费视频 | 午夜视频免费在线观看 | 91视视频在线直接观看在线看网页在线看 | av电影在线播放 | 国产精品你懂的在线观看 | 成人免费视频在线观看 | 国产福利在线免费观看 | 国产精品成人久久久久 | 色婷婷欧美 | 91精品人成在线观看 | 99精品国产99久久久久久福利 | 91视频麻豆| 国产成人一区三区 | 日韩不卡高清视频 | 久久午夜精品视频 | 国产丝袜制服在线 | 日韩激情在线视频 | 丁香综合五月 | 欧美大香线蕉线伊人久久 | www夜夜操com | 亚洲激情av | 精选久久| 伊人五月在线 | 香蕉视频在线免费看 | 午夜精品一区二区三区在线播放 | 亚洲精品午夜国产va久久成人 | av成人免费 | 在线观看视频三级 | 一区二区激情 | 中文字幕在线观看免费高清完整版 | 五月天丁香亚洲 | 91成人精品一区在线播放69 | 精品国产一区二区三区噜噜噜 | 97视频在线看 | 久久乐九色婷婷综合色狠狠182 | 最近中文字幕完整视频高清1 | 国产黄色大片免费看 | 日韩精品一区二区三区在线视频 | 欧美福利网址 | 久久国产精品精品国产色婷婷 | 国产破处视频在线播放 | 日韩欧美一区二区三区在线 | 国产精品久一 | 成人h动漫在线看 | 黄色av电影在线观看 | 日韩在线视频在线观看 | 激情综合婷婷 | 人人舔人人插 | 成人免费在线观看电影 | 国产精品久久久久一区二区国产 | 黄色免费在线看 | 91精品人成在线观看 | 亚州视频在线 | 久久久久女人精品毛片九一 | 深夜激情影院 | 99免费看片 | 国产手机精品视频 | 91在线看网站 | 天天躁日日| 天天操综合网 | 日韩理论电影在线 | 国产精品久久久免费 | 黄色精品一区二区 | 成人动漫精品一区二区 | 日韩欧美综合 | 日本黄色免费看 | 亚洲电影av在线 | 亚洲精品乱码久久久久久蜜桃动漫 | 久久久午夜电影 | 99久久精 | 久久午夜电影院 | 免费日韩在线 | 一区二区 不卡 | 黄色免费网 | 欧洲性视频 | 国产精品自产拍在线观看网站 | 在线免费三级 | 911av视频| 久久精品亚洲一区二区三区观看模式 | 国产精品综合久久久久 | h视频日本 | 三级黄色网络 | 欧美精品小视频 | 就要干b | 色七七亚洲影院 | 国产三级av在线 | 国产一级一片免费播放放 | 日韩美女一级片 | 欧美日韩大片在线观看 | 日韩av视屏在线观看 | 日韩欧美精品在线视频 | 探花视频在线观看免费 | 欧美成人h版电影 | 久久久精品 | 国产91在| 天天人人综合 | 亚洲午夜电影网 | 草在线视频 | 99视频在线免费看 | 久久黄色片 | 天天色 天天 | 午夜精品一区二区三区免费视频 | 成人亚洲欧美 | 国产91大片 | 尤物九九久久国产精品的分类 | 国产视频网站在线观看 | 在线精品视频免费播放 | 欧美日韩国产一区二区三区在线观看 | 亚洲激情五月 | 成人动漫一区二区三区 | 97av色 | 97视频人人免费看 | 国产黄a三级三级三级三级三级 | 深夜激情影院 | 少妇精品久久久一区二区免费 | 日韩av网址在线 | 黄视频网站大全 | 91视视频在线直接观看在线看网页在线看 | av网站大全免费 | 国产尤物在线视频 | 日本爱爱片 | 免费av大全 | 美女网站久久 | 免费看污片 | 最近免费观看的电影完整版 | 2019中文字幕网站 | 国产糖心vlog在线观看 | 天天色天天射天天干 | www.com黄色| 麻豆视频免费入口 | 欧美日韩国产亚洲乱码字幕 | 久草在线视频在线观看 | 韩国一区二区av | 天天草av| 综合伊人av | 婷婷在线播放 | 国产毛片久久 | 日韩欧美xxx | 国产欧美最新羞羞视频在线观看 | 国产综合福利在线 | 综合精品在线 | 久久九九九九 | 亚洲欧美国产精品18p | 国产123区在线观看 国产精品麻豆91 | 国产五十路毛片 | 亚洲高清精品在线 | 亚洲开心色 | av在线免费播放 | 日韩首页 | 亚洲精品456在线播放第一页 | 日韩精品视频在线观看免费 | 久久99久久精品 | 中文 一区二区 | 91精品对白一区国产伦 | 欧美日韩xxxxx| 日韩午夜视频在线观看 | 在线国产中文 | 波多野结衣在线播放视频 | 国产精品999久久久 久产久精国产品 | 91在线产啪 | 久久精品一 | 激情九九 | 午夜精品久久久久久久99婷婷 | 久久久www成人免费精品张筱雨 | 黄色一区二区在线观看 | 国产精品 中文在线 | 五月天久久婷 | 九九九视频精品 | 久久精品国产免费看久久精品 | 成人教育av| 日韩欧美一区视频 | av网站在线观看免费 | 人人人爽 | 久久精品屋 | 久久精品综合视频 | 福利网址在线观看 | 欧洲成人av | 一区二区国产精品 | 最近中文字幕在线中文高清版 | 97免费在线视频 | 日韩精品一区二区三区在线播放 | 久久综合九色九九 | 午夜av大片 | 网站在线观看日韩 | 在线观看一 | 久久精品二区 | 特及黄色片 | 国产精品免费av | 天天插天天 | 日韩视频免费看 | 久久精品国产亚洲精品2020 | 欧美日韩在线观看视频 | 欧美日韩高清免费 | 99热这里只有精品久久 | 久久调教视频 | 中文字幕在线国产 | 久久久久久久久久久精 | 伊人久久国产精品 | 国产1级视频 | 四虎在线视频免费观看 | 男女激情麻豆 | 国产精品美女久久久久久久久 | 中文字幕美女免费在线 | 人人天天夜夜 | 亚洲精品视频偷拍 | 在线影视 一区 二区 三区 | 国产在线欧美在线 | 日本黄色大片免费 | 69国产精品视频免费观看 | 久久精品视频在线观看免费 | 日本中文一级片 | 69热国产视频 | www.夜夜爱| 99亚洲视频| 久久久久久亚洲精品 | 久久影院中文字幕 | 香蕉视频国产在线观看 | 波多野结衣综合网 | 久久精品视频18 | 亚洲精品午夜一区人人爽 | 中文字幕在线视频精品 | 国产打女人屁股调教97 | 亚洲午夜精品在线观看 | 99精品久久久久久久久久综合 | 91午夜精品 | 黄色免费网战 | 久久69精品久久久久久久电影好 | 色.www| 久久久穴 | www.久久久.cum | 三级黄色在线观看 | 国产精品毛片久久久久久 | 亚州精品天堂中文字幕 | 97超碰香蕉 | 欧美精品午夜 | 最新真实国产在线视频 | 国产高h视频| 黄色免费看片网站 | 一区二区三区四区影院 | 永久免费的啪啪网站免费观看浪潮 | 日韩乱色精品一区二区 | 三级av小说 | 99国产视频在线 | 亚洲电影av在线 | 亚洲国产电影在线观看 | 日韩精品一区电影 | 少妇性色午夜淫片aaaze | 欧美激情视频在线观看免费 | 国产精品久久网站 | 婷婷丁香激情五月 | 天天摸天天干天天操天天射 | 69国产精品成人在线播放 | 久久超 | 久久精品99久久久久久 | 中文字幕资源网 | 欧美性生活免费 | 美女视频久久黄 | 色综合久久久久久久 | 欧美 日韩精品 | 成人资源在线 | 国产成人av在线 | 亚洲国产精品免费 | 国产一级一片免费播放放 | 日韩欧美精品一区二区 | 久久99久久99久久 | 亚洲国产精品一区二区久久,亚洲午夜 | 91视频com| av软件在线观看 | 欧美日韩精品久久久 | 欧美日韩一级久久久久久免费看 | 天天曰夜夜爽 | 黄色大全免费网站 | 久精品在线| 欧美日韩精品影院 | 在线色吧 | 麻豆视频在线看 | 91久久久久久久一区二区 | 最新色站 | 精品免费国产一区二区三区四区 | 久久国产精品免费一区二区三区 | 日本性动态图 | 国产精品av免费在线观看 | 中文字幕观看在线 | 久久久久久99精品 | 狠狠色网 | 永久免费毛片 | 久久视频在线 | 亚洲精品国产精品国自产在线 | 久久久在线视频 | www.黄色小说.com | 成人午夜在线电影 | 久久精品综合网 | 中文字幕一区二区三区精华液 | 97电影在线 | 最新极品jizzhd欧美 | 久久久久久久网 | 国内成人精品视频 | 国产精品九九九 | 日本在线观看一区二区 | 久久国产精品久久精品国产演员表 | 日韩1页 | 91av中文| 中日韩免费视频 | 精品成人在线 | 玖玖视频国产 | 一区二区三区日韩精品 | 国产亚洲日 | 精品影院 | 在线久热 | 久久综合之合合综合久久 | 午夜精品一区二区三区在线观看 | 中文字幕在线观看网站 | 欧美精品久久久久久久久久丰满 | 国色天香在线观看 | 黄色片网站av | 精品福利在线 | 97在线免费视频观看 | 国产一区视频在线观看免费 | 日韩免费三区 | 国产成人av电影 | 91九色网站 | 成人在线中文字幕 | 亚洲国产精品999 | 激情视频综合网 | 日韩女同一区二区三区在线观看 | 黄色亚洲片| 深爱激情五月婷婷 | 国产精品国产三级国产 | 日韩视频在线不卡 | 国产成人亚洲在线观看 | 国产成人一级 | 在线观看成人小视频 | 一区二区三区观看 | 日韩中文字幕在线看 | 免费三级骚| 99人久久精品视频最新地址 | 日韩高清片 | 99在线精品免费视频九九视 | 日日夜夜精品视频天天综合网 | 91大片成人网| 91热视频| 日本精a在线观看 | 国产91全国探花系列在线播放 | 亚洲精品a区 | 国产精品久久久影视 | 五月婷婷综合色拍 | 国产原创中文在线 | 伊人成人久久 | 久久国产片| 精品久久久久久久久久久久 | 美女免费视频网站 | 中国一级片免费看 | 国产91丝袜在线播放动漫 | 久久综合亚洲鲁鲁五月久久 |