<groupId>org.projectlombokgroupId>
<artifactId>lombokartifactId>
<artifactId>junitartifactId>
<artifactId>mysql-connector-javaartifactId>
package com.csdn.fruit.pojo;
import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;
import java.io.Serializable;
public class Fruit implements Serializable {
public Fruit(String fname, Integer price, Integer fcount, String remark) {
public String toString() {
return fname + "\t\t" + price + "\t\t" + fcount + "\t\t" + remark;
jdbc.driver=com.mysql.cj.jdbc.Driver
package com.csdn.mymvc.dao;
import com.csdn.mymvc.util.ClassUtil;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Properties;
public abstract class BaseDao {
private String entityClassName;
ParameterizedType genericSuperclass = (ParameterizedType) this.getClass().getGenericSuperclass();
Type[] actualTypeArguments = genericSuperclass.getActualTypeArguments();
Type actualTypeArgument = actualTypeArguments[0];
entityClassName = actualTypeArgument.getTypeName();
private void loadJdbcProperties() {
InputStream inputStream = getClass().getClassLoader().getResourceAsStream("jdbc.properties");
Properties properties = new Properties();
properties.load(inputStream);
DRIVER = properties.getProperty("jdbc.driver", "com.mysql.cj.jdbc.Driver");
URL = properties.getProperty("jdbc.url", "jdbc:mysql:///fruitdb");
USER = properties.getProperty("jdbc.user", "root");
PWD = properties.getProperty("jdbc.pwd", "123456");
} catch (IOException e) {
throw new RuntimeException(e);
private Connection getConn() {
return DriverManager.getConnection(URL, USER, PWD);
} catch (ClassNotFoundException | SQLException e) {
throw new RuntimeException(e);
private void close(Connection conn, PreparedStatement psmt, ResultSet rs) {
if (conn != null && !conn.isClosed()) {
} catch (SQLException e) {
throw new RuntimeException(e);
protected int executeUpdate(String sql, Object... params) {
PreparedStatement psmt = null;
psmt = conn.prepareStatement(sql);
return psmt.executeUpdate();
} catch (SQLException e) {
throw new RuntimeException(e);
private void setParams(PreparedStatement psmt, Object... params) throws SQLException {
if (params != null && params.length > 0) {
for (int i = 0; i < params.length; i++) {
psmt.setObject(i + 1, params[i]);
protected List executeQuery(String sql, Object... params) {
List list = new ArrayList<>();
PreparedStatement psmt = null;
psmt = conn.prepareStatement(sql);
rs = psmt.executeQuery();
ResultSetMetaData rsmd = rs.getMetaData();
T t = (T) ClassUtil.createInstance(entityClassName);
int columnCount = rsmd.getColumnCount();
for (int i = 1; i <= columnCount; i++) {
String columnName = rsmd.getColumnLabel(i);
Object columnValue = rs.getObject(i);
ClassUtil.setProperty(t, columnName, columnValue);
} catch (SQLException e) {
throw new RuntimeException(e);
protected T load(String sql, Object... params) {
PreparedStatement psmt = null;
psmt = conn.prepareStatement(sql);
rs = psmt.executeQuery();
ResultSetMetaData rsmd = rs.getMetaData();
T t = (T) ClassUtil.createInstance(entityClassName);
int columnCount = rsmd.getColumnCount();
for (int i = 1; i <= columnCount; i++) {
String columnName = rsmd.getColumnLabel(i);
Object columnValue = rs.getObject(i);
ClassUtil.setProperty(t, columnName, columnValue);
} catch (SQLException e) {
throw new RuntimeException(e);

package com.csdn.mymvc.util;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
public static Object createInstance(String entityClassName) {
return Class.forName(entityClassName).getDeclaredConstructor().newInstance();
} catch (InstantiationException | IllegalAccessException | InvocationTargetException | NoSuchMethodException |
ClassNotFoundException e) {
throw new RuntimeException(e);
public static void setProperty(Object instance, String propertyName, Object propertyValue) {
Class> aClass = instance.getClass();
Field field = aClass.getDeclaredField(propertyName);
field.setAccessible(true);
field.set(instance, propertyValue);
} catch (NoSuchFieldException | IllegalAccessException e) {
throw new RuntimeException(e);
package com.csdn.fruit.dao;
import com.csdn.fruit.pojo.Fruit;
public interface FruitDao {
void addFruit(Fruit fruit);
void delFruit(String fname);
void updateFruit(Fruit fruit);
Fruit getFruitByFname(String fname);
package com.csdn.fruit.dao.impl;
import com.csdn.fruit.dao.FruitDao;
import com.csdn.fruit.pojo.Fruit;
import com.csdn.mymvc.dao.BaseDao;
public class FruitDaoImpl extends BaseDao implements FruitDao {
public void addFruit(Fruit fruit) {
String sql = "insert into t_fruit values (0,?,?,?,?)";
super.executeUpdate(sql, fruit.getFname(), fruit.getPrice(), fruit.getFcount(), fruit.getRemark());
public void delFruit(String fname) {
String sql = "delete from t_fruit where fname=?";
super.executeUpdate(sql, fname);
public void updateFruit(Fruit fruit) {
String sql = "update t_fruit set fcount=? where fname = ?";
super.executeUpdate(sql, fruit.getFcount(), fruit.getFname());
public List getFruitList() {
return super.executeQuery("select * from t_fruit");
public Fruit getFruitByFname(String fname) {
return load("select * from t_fruit where fname = ?", fname);
package com.csdn.fruit.view;
import com.csdn.fruit.dao.FruitDao;
import com.csdn.fruit.dao.impl.FruitDaoImpl;
import com.csdn.fruit.pojo.Fruit;
import java.util.Scanner;
Scanner input = new Scanner(System.in);
private FruitDao fruitDao = new FruitDaoImpl();
public int showMainMenu() {
System.out.println("================欢迎使用水果库存系统===================");
System.out.println("1.显示库存列表");
System.out.println("2.添加库存记录");
System.out.println("3.查看特定库存");
System.out.println("4.水果下架");
System.out.println("5.退出");
System.out.println("====================================================");
System.out.print("请选择:");
public void showFruitList() {
List fruitList = fruitDao.getFruitList();
System.out.println("----------------------------------------------------");
System.out.println("名称\t\t单价\t\t库存\t\t备注");
if (fruitList == null || fruitList.size() <= 0) {
System.out.println("对不起,库存为空!");
fruitList.forEach(System.out::println);
System.out.println("----------------------------------------------------");
System.out.print("请输入水果名称:");
String fname = input.next();
Fruit fruit = fruitDao.getFruitByFname(fname);
System.out.print("请输入水果单价:");
Integer price = input.nextInt();
System.out.print("请输入水果库存:");
Integer fcount = input.nextInt();
System.out.print("请输入水果备注:");
String remark = input.next();
fruit = new Fruit(fname, price, fcount, remark);
fruitDao.addFruit(fruit);
System.out.print("请输入追加的库存量:");
Integer fcount = input.nextInt();
fruit.setFcount(fruit.getFcount() + fcount);
fruitDao.updateFruit(fruit);
System.out.println("添加成功!");
public void showFruitInfo() {
System.out.print("请输入水果名称:");
String fname = input.next();
Fruit fruit = fruitDao.getFruitByFname(fname);
System.out.println("对不起,没有找到对应的库存记录!");
System.out.println("----------------------------------------------------");
System.out.println("名称\t\t单价\t\t库存\t\t备注");
System.out.println(fruit);
System.out.println("----------------------------------------------------");
System.out.print("请输入水果名称:");
String fname = input.next();
Fruit fruit = fruitDao.getFruitByFname(fname);
System.out.println("对不起,没有找到需要下架的库存记录!");
System.out.print("是否确认下架?(Y/N)");
String confirm = input.next();
if ("y".equalsIgnoreCase(confirm)) {
fruitDao.delFruit(fname);
System.out.print("是否确认退出?(Y/N)");
String confirm = input.next();
boolean flag= !"y".equalsIgnoreCase(confirm);

package com.csdn.fruit.view;
public static void main(String[] args) {
int slt = m.showMainMenu();
System.out.println("你不按套路出牌!");
System.out.println("谢谢使用!再见!");
package com.csdn.dao.impl;
import com.csdn.fruit.dao.FruitDao;
import com.csdn.fruit.dao.impl.FruitDaoImpl;
import com.csdn.fruit.pojo.Fruit;
public class FruitDaoImplTest {
private FruitDao fruitDao = new FruitDaoImpl();
public void testAddFruit() {
Fruit fruit = new Fruit("香蕉", 7, 77, "波罗蜜是一种神奇的水果!");
fruitDao.addFruit(fruit);
public void testDelFruit() {
fruitDao.delFruit("哈密瓜");
public void testUpdateFruit() {
Fruit fruit = new Fruit("波罗蜜", 5, 1000, "好吃");
fruitDao.updateFruit(fruit);
public void testGetFruitList() {
List fruitList = fruitDao.getFruitList();
fruitList.stream().forEach(System.out::println);
public void testGetFruitByFname() {
Fruit fruit = fruitDao.getFruitByFname("波罗蜜");
System.out.println(fruit);
public void testActualTypeArgument() {