项目内容就不详细介绍了,主要锻炼数据库增删改查,及项目逻辑调用。
代码有点多,按照package顺序,运行包–视图包–服务包–数据库操作包–工具包–事物对象包
以及SQL语句。
运行类
package cn.gjp.app;
import cn.gjp.view.MainView;
/*
* 运行管家婆的主方法
*/
public class MainApp {
public static void main(String[] args) {
new MainView().run();
}
}
视图类
package cn.gjp.view;
import java.util.List;
import java.util.Scanner;
import cn.gjp.domain.ZhangWu;
import cn.gjp.service.ZhangWuService;
/*
* 依赖service
*/
public class MainView {
private ZhangWuService zws = new ZhangWuService();
/*
* 实现键盘输入,选择相应功能调用
*/
public void run(){
Scanner sc = new Scanner(System.in);
while(true){
System.out.println("---------------管家婆家庭记账软件---------------");
System.out.println("1.添加账务 2.编辑账务 3.删除账务 4.查询账务 5.退出系统");
System.out.println("请输入要操作的功能序号[1-5]:");
int choose = sc.nextInt();
switch(choose){
case 1:
//选择添加账务
addZhangWu();
break;
case 2:
//选择编辑
editZhangWu();
break;
case 3:
//选择删除账务
deleteZhangWu();
break;
case 4:
//选择查询账务
selectZhangWu();
break;
case 5:
//退出系统
System.exit(0);
break;
}
}
}
/*
* 删除账务
*/
public void deleteZhangWu(){
ZhangWu zw = new ZhangWu();
Scanner sc = new Scanner(System.in);
System.out.println("请输入要删除的ID:");
zw.setZwid(sc.nextInt());
boolean b = new ZhangWuService().deleteZhangWu(zw);
if(b){
System.out.println("删除成功!");
}
}
/*
* 编辑账务
*/
public void editZhangWu(){
ZhangWu zw = new ZhangWu();
Scanner sc = new Scanner(System.in);
System.out.println("请输入要编辑的ID:");
zw.setZwid(sc.nextInt());
System.out.println("请输入类别:");
zw.setFlname(sc.next());
System.out.println("请输入花费:");
zw.setMoney(sc.nextDouble());
System.out.println("请输入账户:");
zw.setZhangHu(sc.next());
System.out.println("请输入时间:");
zw.setCreatetime(sc.next());
System.out.println("请输入说明:");
zw.setDescription(sc.next());
boolean b = new ZhangWuService().editZhangWu(zw);
if(b){
System.out.println("编辑成功!");
}
}
/*
* 添加账务功能
*/
public void addZhangWu(){
ZhangWu zw = new ZhangWu();
Scanner sc = new Scanner(System.in);
System.out.println("请输入类别:");
zw.setFlname(sc.next());
System.out.println("请输入花费:");
zw.setMoney(sc.nextDouble());
System.out.println("请输入账户:");
zw.setZhangHu(sc.next());
System.out.println("请输入时间:");
zw.setCreatetime(sc.next());
System.out.println("请输入说明:");
zw.setDescription(sc.next());
boolean b = new ZhangWuService().addZhangWu(zw);
if(b){
System.out.println("添加成功!");
}
}
/*
* 查询账务功能
*/
public void selectZhangWu(){
System.out.println("请输入查询方式 1:查询所有 2:条件查询");
Scanner sc = new Scanner(System.in);
int i = sc.nextInt();
switch(i){
case 1:
List<ZhangWu> list1 = new ZhangWuService().selectAll();
print(list1);
break;
case 2:
Scanner sc1 = new Scanner(System.in);
System.out.println("请输入起始时间:");
String starttime = sc1.nextLine();
System.out.println("请输入结束时间:");
String endtime = sc1.nextLine();
List<ZhangWu> list2 = new ZhangWuService().select(starttime,endtime);
print(list2);
break;
}
}
public void print(List<ZhangWu> list){
System.out.println("编号\t"+"名称\t"+"花费\t"+"账户\t"+"时间\t"+"说明\t");
for (ZhangWu zw : list) {
System.out.println(zw.getZwid()+"\t"+zw.getFlname()+"\t"+zw.getMoney()+"\t"+zw.getZhangHu()+"\t"+zw.getCreatetime()+"\t"+zw.getDescription());
}
}
}
服务类
package cn.gjp.service;
import java.util.List;
import java.util.Scanner;
import cn.gjp.dao.ZhangWuDao;
import cn.gjp.domain.ZhangWu;
import cn.gjp.view.MainView;
/*
* 用于传递参数,依赖zhangwudao
*/
public class ZhangWuService {
private ZhangWuDao zwd = new ZhangWuDao();
/*
* 删除账务
*/
public boolean deleteZhangWu(ZhangWu zw){
return new ZhangWuDao().deleteZhangWu(zw);
}
/*
* 编辑账务
*/
public boolean editZhangWu(ZhangWu zw){
return new ZhangWuDao().editZhangWu(zw);
}
/*
* 添加账务
*/
public boolean addZhangWu(ZhangWu zw){
return new ZhangWuDao().addZhangWu(zw);
}
/*
* 查询所有账务信息,调用dao查询数据库
*/
public List<ZhangWu> selectAll(){
List<ZhangWu> list = new ZhangWuDao().selectAll();
return list;
}
/*
* 条件查询账务信息
*/
public List<ZhangWu> select(String starttime,String endtime){
List<ZhangWu> list = new ZhangWuDao().select(starttime,endtime);
return list;
}
}
操作数据库类
package cn.gjp.dao;
import java.sql.SQLException;
import java.util.List;
import javax.management.RuntimeErrorException;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import cn.gjp.domain.ZhangWu;
import cn.gjp.tools.JDBCUtils;
/*
* 添加queryrunner对象,用来操作数据库数据。
*/
public class ZhangWuDao {
QueryRunner qr = new QueryRunner(JDBCUtils.getDataSource());
/*
* 删除账务
*/
public boolean deleteZhangWu(ZhangWu zw){
String sql = "DELETE FROM gjp_zhangwu WHERE zwid=?";
try{
qr.update(sql,zw.getZwid());
return true;
}catch (SQLException sex){
System.out.println(sex);
throw new RuntimeException("删除失败");
}
}
/*
* 编辑账务
*/
public boolean editZhangWu(ZhangWu zw){
String sql = "UPDATE gjp_zhangwu SET flname=?,money=?,zhangHu=?,createtime=?,description=? WHERE zwid = ?";
//String sql = "update gjp_zhangwu set flname=?, money=?,zhanghu=?,createtime=?,description=? where zwid=?";
Object[] parms = {zw.getFlname(),zw.getMoney(),zw.getZhangHu(),zw.getCreatetime(),zw.getDescription(),zw.getZwid()};
try{
qr.update(sql, parms);
return true;
}catch (SQLException sex){
System.out.println(sex);
throw new RuntimeException("编辑失败");
}
}
/*
* 添加账务
*/
public boolean addZhangWu(ZhangWu zw){
String sql = "insert into gjp_zhangwu(flname,money,zhangHu,createtime,description) values(?,?,?,?,?)";
Object[] parms = {zw.getFlname(),zw.getMoney(),zw.getZhangHu(),zw.getCreatetime(),zw.getDescription()};
try{
qr.update(sql, parms);
return true;
}catch (SQLException sex){
System.out.println(sex);
throw new RuntimeException("添加失败");
}
}
/*
* 查询所有账务信息
*/
public List<ZhangWu> selectAll(){
try{
String sql = "SELECT * FROM gjp_zhangwu";
List<ZhangWu> list = qr.query(sql,new BeanListHandler<>(ZhangWu.class));
return list;
}catch (Exception e) {
System.out.println(e);
throw new RuntimeException("查询失败");
}
}
/*
* 条件查询账务信息
*/
public List<ZhangWu> select(String starttime,String endtime){
try{
String sql = "SELECT * FROM gjp_zhangwu WHERE createtime BETWEEN ? AND ?";
Object[] parms = {starttime,endtime};
List<ZhangWu> list = qr.query(sql,new BeanListHandler<>(ZhangWu.class),parms);
return list;
}catch (Exception e) {
System.out.println(e);
throw new RuntimeException("查询失败");
}
}
}
账务数据类型类
package cn.gjp.domain;
/*
* 封装数据库中数据为javabean类对象
*/
public class ZhangWu {
private int zwid ;
private String flname;
private double money ;
private String zhangHu;
private String createtime;
private String description;
public ZhangWu(int zwid, String flname, double money, String zhangHu,
String createtime, String description) {
this.zwid = zwid;
this.flname = flname;
this.money = money;
this.zhangHu = zhangHu;
this.createtime = createtime;
this.description = description;
}
public ZhangWu(){}
public int getZwid() {
return zwid;
}
public void setZwid(int zwid) {
this.zwid = zwid;
}
public String getFlname() {
return flname;
}
public void setFlname(String flname) {
this.flname = flname;
}
public double getMoney() {
return money;
}
public void setMoney(double money) {
this.money = money;
}
public String getZhangHu() {
return zhangHu;
}
public void setZhangHu(String zhangHu) {
this.zhangHu = zhangHu;
}
public String getCreatetime() {
return createtime;
}
public void setCreatetime(String createtime) {
this.createtime = createtime;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String toString() {
return "ZhangWu [zwid=" + zwid + ", flname=" + flname + ", money="
+ money + ", zhangHu=" + zhangHu + ", createtime=" + createtime
+ ", description=" + description + "]";
}
}
数据库连接工具类,注意我的数据库连接端口号是3307,密码是123456
package cn.gjp.tools;
import javax.sql.DataSource;
import org.apache.commons.dbcp.BasicDataSource;
/*
* 数据库连接工具类
* 连接池,dbcp
*/
public class JDBCUtils {
private static BasicDataSource datasource = new BasicDataSource();
//静态代码块实现必要的参数设置
static{
datasource.setDriverClassName("com.mysql.jdbc.Driver");
datasource.setUrl("jdbc:mysql://localhost:3307/gjp");
datasource.setUsername("root");
datasource.setPassword("123456");
datasource.setMaxActive(10);
datasource.setMaxIdle(5);
datasource.setMinIdle(3);
datasource.setInitialSize(8);
}
public static DataSource getDataSource(){
return datasource;
}
}
SQL
CREATE DATABASE gjp;
USE gjp;
CREATE TABLE gjp_zhangwu(
zwid INT PRIMARY KEY AUTO_INCREMENT,
flname VARCHAR(200),
money DOUBLE,
zhangHu VARCHAR(200),
createtime DATE,
description VARCHAR(100)
);
-- insert into gjp_zhangwu(flname,money,zhanghu,createtime,description) values (,,,,)
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (1,'吃饭支出',247,'交通银行','2016-03-02','家庭聚餐');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (2,'工资收入',12345,'现金','2016-03-15','开工资了');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (3,'服装支出',1998,'现金','2016-04-02','买衣服');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (4,'吃饭支出',325,'现金','2016-06-18','朋友聚餐');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (5,'股票收入',8000,'工商银行','2016-10-28','股票大涨');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (6,'股票收入',5000,'工商银行','2016-10-28','股票又大涨');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (7,'工资收入',5000,'交通银行','2016-10-28','又开工资了');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (8,'礼金支出',5000,'现金','2016-10-28','朋友结婚');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (9,'其他支出',1560,'现金','2016-10-29','丢钱了');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (10,'交通支出',2300,'交通银行','2016-10-29','油价还在涨啊');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (11,'吃饭支出',1000,'工商银行','2016-10-29','又吃饭');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (12,'工资收入',1000,'现金','2016-10-30','开资');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (13,'交通支出',2000,'现金','2016-10-30','机票好贵');
INSERT INTO gjp_zhangwu(zwid,flname,money,zhangHu,createtime,description) VALUES (14,'工资收入',5000,'现金','2016-10-30','又开资');
-- 查询全部
SELECT * FROM gjp_zhangwu;
-- 条件查询
SELECT * FROM gjp_zhangwu WHERE createtime BETWEEN 20160106 AND 20160808;
-- 添加账务
INSERT INTO gjp_zhangwu (flname,money,zhangHu,createtime,description)
VALUES ('彩票支出',200,'现金','20200410','欧洲杯');
-- 编辑账务
UPDATE gjp_zhangwu SET flname='dsf',money=250,zhangHu='asdf',createtime='21000809',description='safdgsadfg'
WHERE zwid = 15;
-- 删除账务
DELETE FROM gjp_zhangwu WHERE zwid=15;