用MySQL建立一个数据存储各种食物的营养成分的表。
用Java编程,提供图形用户界面,实现下面的功能之一:
- 实现按照营养成分的多种查询
- 实现食物营养成分修改、添加、删除
效果图:
部分代码如下:
package info;
import java.awt.BorderLayout;
import java.awt.Frame;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.swing.JButton;
import javax.swing.JDialog;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField;
public class FoodAddDialog extends JDialog implements ActionListener{
//定义我需要的swing组件
JLabel jl1,jl2,jl3,jl4,jl5,jl6,jl7;
JButton jb1,jb2;
JTextField jtf1,jtf2,jtf3,jtf4,jtf5,jtf6,jtf7;
JPanel jp1,jp2,jp3;
//owner它的父窗口;title窗口名;model指定是模态窗口,还是非模态
public FoodAddDialog(Frame owner,String title,boolean modal){
super(owner,title,modal);//调用父类构造方法,达到模式对话框效果
jl1=new JLabel("食物名称");
jl2=new JLabel("蛋白质");
jl3=new JLabel("脂肪");
jl4=new JLabel("碳水化合物");
jl5=new JLabel("热量");
jl6=new JLabel("无机盐类");
jl7=new JLabel("钙");
jtf1=new JTextField();
jtf2=new JTextField();
jtf3=new JTextField();
jtf4=new JTextField();
jtf5=new JTextField();
jtf6=new JTextField();
jtf7=new JTextField();
jb1=new JButton("添加");
jb2=new JButton("取消");
jp1=new JPanel();
jp2=new JPanel();
jp3=new JPanel();
//设置布局
jp1.setLayout(new GridLayout(7,1));
jp2.setLayout(new GridLayout(7,1));
//添加组件
jp1.add(jl1);
jp1.add(jl2);
jp1.add(jl3);
jp1.add(jl4);
jp1.add(jl5);
jp1.add(jl6);
jp1.add(jl7);
jp2.add(jtf1);
jp2.add(jtf2);
jp2.add(jtf3);
jp2.add(jtf4);
jp2.add(jtf5);
jp2.add(jtf6);
jp2.add(jtf7);
jp3.add(jb1);
jp3.add(jb2);
this.add(jp1,BorderLayout.WEST);
this.add(jp2,BorderLayout.CENTER);
this.add(jp3,BorderLayout.SOUTH);
jb1.addActionListener(this);
jb2.addActionListener(this);
//展现
this.setSize(700, 650);
this.setVisible(true);
}
@Override
public void actionPerformed(ActionEvent e) {
//用户点击添加按钮后的响应动作
if(e.getSource()==jb1){
//连接数据库
Connection ct=null;
Statement stmt=null;
ResultSet rs=null;
PreparedStatement ps=null;
//连接数据库
try {
//1、加载驱动
Class.forName("com.mysql.cj.jdbc.Driver");
//2、得到连接
ct=DriverManager.getConnection("jdbc:mysql://localhost:3306/food?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8&useSSL=false","fzj","Fzj990616");
String strsql="insert into 营养成分 values(?,?,?,?,?,?,?)";
ps=ct.prepareStatement(strsql);
ps.setString(1,jtf1.getText());
ps.setString(2,jtf2.getText());
ps.setString(3,jtf3.getText());
ps.setString(4,jtf4.getText());
ps.setString(5,jtf5.getText());
ps.setString(6,jtf6.getText());
ps.setString(7,jtf7.getText());
ps.executeUpdate();
this.dispose();
} catch (Exception e2) {
e2.printStackTrace();
}finally{
try {
if(ps!=null){
ps.close();
}
if(ct!=null){
ct.close();
}
} catch (SQLException e1) {
e1.printStackTrace();
}
}
}
else if(e.getSource()==jb2){
this.dispose();
}
}
}
package info;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Vector;
import javax.swing.JOptionPane;
import javax.swing.table.AbstractTableModel;
public class FoodModel extends AbstractTableModel{
//rowData用来存放行数据、columnNames存放列名
Vector rowData,columnNames;
//添加学生(增、删、改)
public boolean updStu(String sql,String []paras){
//创建SqlHelper(如果程序并发性不考虑,可以把SqlHelper做成static)
SqlHelper sqlHelper=new SqlHelper();
return sqlHelper.updExecute(sql, paras);
}
//查询的本质就是用来初始化
public void queryStu(String sql,String []paras){
SqlHelper sqlHelper=null;
//中间
columnNames=new Vector();
//设置列名
columnNames.add("食物名称");
columnNames.add("蛋白质");
columnNames.add("脂肪");
columnNames.add("碳水化合物");
columnNames.add("热量");
columnNames.add("无机盐类");
columnNames.add("钙");
rowData=new Vector();
//rowData可以存放多行
try {
sqlHelper=new SqlHelper();
ResultSet rs=sqlHelper.queryExectue(sql, paras);
while(rs.next()){
Vector hang=new Vector();
hang.add(rs.getString(1));
hang.add(rs.getFloat(2));
hang.add(rs.getFloat(3));
hang.add(rs.getFloat(4));
hang.add(rs.getFloat(5));
hang.add(rs.getFloat(6));
hang.add(rs.getFloat(7));
//加入rowData
rowData.add(hang);
}
} catch (Exception e) {
e.printStackTrace();
}finally{
sqlHelper.close();
}
}
//得到共有多少列
public int getColumnCount() {
return this.columnNames.size();
}
@Override
public String getColumnName(int column) {
return (String)this.columnNames.get(column);
}
//得到共有多少行
public int getRowCount() {
return this.rowData.size();
}
//得到某行某列的数据
public Object getValueAt(int rowIndex, int columnIndex) {
return ((Vector)this.rowData.get(rowIndex)).get(columnIndex);
}
}
package info;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.swing.JOptionPane;
public class SqlHelper {
public static void main(
String[] args) {
new SqlHelper();
}
//定义操作数据库需要的组件
PreparedStatement ps=null;
Connection ct=null;
ResultSet rs=null;
String sqlDriver="com.mysql.cj.jdbc.Driver";
String url="jdbc:mysql://localhost:3306/food?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8&useSSL=false";
public SqlHelper(){
try {
//1、加载驱动
Class.forName(sqlDriver);
//2、得到连接
ct=DriverManager.getConnection(url,"fzj","Fzj990616");
// DatabaseMetaData dbmd=ct.getMetaData();
// System.out
// .println("数据库版本"+dbmd.getDatabaseProductName());
} catch (Exception e) {
e.printStackTrace();
}
}
//关闭数据库资源
public void close(){
try {
if(rs!=null){
rs.close();
}
if(ps!=null){
ps.close();
}
if(ct!=null){
ct.close();
}
} catch (SQLException e1) {
e1.printStackTrace();
}
}
//写一个不需要注入的方法(由于数据量少,所以写了一个这个方法。一般都带有条件的注入)
public ResultSet queryExectue(String sql){
try {
//3、创建ps
ps=ct.prepareStatement(sql);
rs=ps.executeQuery();
} catch (Exception e) {
e.printStackTrace();
}finally{
//关闭资源???
}
return rs;
}
//对数据库的查询操作
public ResultSet queryExectue(String sql,String []paras){
try {
//3、创建ps
ps=ct.prepareStatement(sql);
//给ps的问号赋值
for(int i=0;i<paras.length;i++){
ps.setString(i+1, paras[i]);
}
rs=ps.executeQuery();
} catch (Exception e) {
e.printStackTrace();
}finally{
//关闭资源???
}
return rs;
}
//把对数据库的增、删、改合在一起
public boolean updExecute(String sql,String []paras){
boolean b=true;
try {
//3、创建ps
ps=ct.prepareStatement(sql);
//给ps的问号赋值
for(int i=0;i<paras.length;i++){
ps.setString(i+1, paras[i]);
}
//4、执行操作
if(ps.executeUpdate()!=1){
b=false;
}
} catch (Exception e) {
b=false;
JOptionPane.showMessageDialog(null, "数据源错误或数据库用户名、密码错误", "数据库连接错误提示", JOptionPane.ERROR_MESSAGE);
e.printStackTrace();
}finally{
this.close();
}
return b;
}
}