38、Java——汽车租赁系统(JDBC+MySQL+Apache DBUtils)

news/2024/11/16 10:22:59/

✅作者简介:热爱国学的Java后端开发者,修心和技术同步精进。

🍎个人主页:乐趣国学的博客

🍊个人信条:不迁怒,不贰过。小知识,大智慧。

💞当前专栏:Java案例分享专栏

✨特色专栏:国学周更-心性养成之路

🥭本文内容:Java——汽车租赁系统(JDBC+MySQL+Apache DBUtils)

更多内容点击👇

                       Java——汽车租赁系统(对象+JDBC)

                       Java——汽车租赁系统(对象+XML)

                       Java——汽车租赁系统(对象+集合)

                       Java——汽车租赁系统(对象+数组)

本文目录

        覆盖知识

        项目需求

        设计步骤 

        开发思路 

        类的属性和方法

        代码展示

        效果展示


覆盖知识

        程序基本概念、数据类型、流程控制、顺序、选择 、循环、跳转语句、变量、类、方法、继承、多态。
        掌握数据库、JDBC、三层架构等相关知识。
        掌握Druid连接池、Apache的DBUtils使用 。

项目需求

        某汽车租赁公司出租多种轿车和客车,出租费用以日为单位计算。

        出租车型及信息如下表所示:

车型

具体信息

日租金

折扣

轿车

宝马X6(京NY28588)

800

days>7天9折

days>30天8折

days>150天7折

宝马550i(京CNY3284)

600

别克林荫大道(京NT37465)

300

别克GL8(京NT96968)

600

客车

金杯,16座(京6566754)

800

days>=3天9折

days>=7天8折

days>=30天7折

days>=150天6折

金龙,16座(京8696997)

金杯,34座(京9696996)

1500

金龙,34座(京8696998)

设计步骤 

开发思路 

        (1)明确需求

        (2)编码顺序

                1)、添加需要的jar包到项目中,将lib文件夹中的jar文件通过鼠标右单击选择Build Path的方式添加到你设置的eatJar文件目录里。

                2)、创建database.properties文件,用来配置注册驱动和数据库连接对象的相关数据。

driver=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/java221804

username=root

password=huanghuang

initialSize=10

maxActive=30

maxIdle=5

maxWait=3000

                3)、添加需要的工具类DBUtils类

package cn.eat.utils;import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;import javax.sql.DataSource;import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.pool.DruidDataSourceFactory;public class DBUtils {private static DruidDataSource druidDataSource;static {Properties properties = new Properties();try {InputStream is = DBUtils.class.getResourceAsStream("/database.properties");properties.load(is);druidDataSource = (DruidDataSource) DruidDataSourceFactory.createDataSource(properties);} catch (IOException e) {e.printStackTrace();} catch (Exception e) {e.printStackTrace();}}public static DataSource getDataSource(){return druidDataSource;}}

                4)、创建数据表:automobile表

CREATE TABLE `automobile` (`numberPlate` varchar(20) DEFAULT NULL,`brand` varchar(10) DEFAULT NULL,`dayRent` double DEFAULT NULL,`type` varchar(10) DEFAULT NULL,`seat` int(11) DEFAULT NULL
) 

     automobile表效果展示 

                5)、完成父类(汽车类)的编写

                6)、再完成子类(客车类和轿车类)的编写

                7)、数据访问层DAO层的接口和实现类的增删改查方法的编写

                8)、服务层Service层的接口和实现类的增删改查方法的编写

                9)、最后完成视图层View层测试类的编写

类的属性和方法

属性:

  • 汽车类:车牌号、品牌、日租金
  • 客车类:车牌号、品牌、日租金、座位数
  • 轿车类:车牌号、品牌、日租金、型号
  • 汽车业务类:忽略
  • 汽车租赁管理类:忽略

方法: 

        定义租车的方法,不同类型的汽车采用不同租金方法进行计算。

代码展示

1、汽车类(父类)

package cn.automobile.entity;public abstract class Automobile {// 定义汽车类的属性(车牌号、品牌、日租金)private String numberPlate;private String brand;private double dayRent;public Automobile() {super();}public Automobile(String numberPlate, String brand, double dayRent) {super();this.numberPlate = numberPlate;this.brand = brand;this.dayRent = dayRent;}public String getNumberPlate() {return numberPlate;}public void setNumberPlate(String numberPlate) {this.numberPlate = numberPlate;}public String getBrand() {return brand;}public void setBrand(String brand) {this.brand = brand;}public double getDayRent() {return dayRent;}public void setDayRent(double dayRent) {this.dayRent = dayRent;}//定义计算租金的抽象方法public abstract double calRent(int days,double dayRent);@Overridepublic String toString() {return "Automobile [numberPlate=" + numberPlate + ", brand=" + brand+ ", dayRent=" + dayRent + "]";}}

2、轿车类(子类)

package cn.automobile.entity;public class Bus extends Automobile {private int seat;public Bus() {super();}public Bus(String numberPlate, String brand, double dayRent, int seat) {super(numberPlate, brand, dayRent);this.seat = seat;}public int getSeat() {return seat;}public void setSeat(int seat) {this.seat = seat;}@Overridepublic double calRent(int days,double dayRent) {
//		System.out.println("bus");double discount=dayRent*days;if(days>150){discount*=0.6;}else if(days>30){discount*=0.7;}else if(days>7){discount*=0.8;}else if(days>3){discount*=0.9;}return discount;}}

3、客车类(子类)

package cn.automobile.entity;public class Car extends Automobile {// 定义特有属性private String type;public Car() {super();}public Car(String numberPlate, String brand, double dayRent, String type) {super(numberPlate, brand, dayRent);this.type = type;}public String getType() {return type;}public void setType(String type) {this.type = type;}@Overridepublic double calRent(int days,double dayRent) {
//		System.out.println("car");double discount=dayRent*days;if(days>150){discount*=0.7;}else if(days>30){discount*=0.8;}else if(days>7){discount*=0.9;}return discount;}}

4、数据访问层AutomobileDao接口

package cn.automobile.dao;import cn.automobile.entity.Automobile;
import cn.automobile.entity.Bus;
import cn.automobile.entity.Car;public interface AutomobileDao {//查busAutomobile selectOne(Bus bus);//查carAutomobile selectOne(Car car);
}

5、数据访问层AutomobileDaoImpl实现类

package cn.automobile.dao.Impl;import java.sql.SQLException;
import java.util.List;import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;import cn.automobile.dao.AutomobileDao;
import cn.automobile.entity.Automobile;
import cn.automobile.entity.Bus;
import cn.automobile.entity.Car;
import cn.automobile.utils.DBUtils;public class AutomobileDaoImpl implements AutomobileDao {private QueryRunner queryRunner = new QueryRunner(DBUtils.getDataSource());@Overridepublic Automobile selectOne(Bus bus) {String sql="select * from automobile;";try {List<Bus> listAutomobiles=queryRunner.query(sql, new BeanListHandler<Bus>(Bus.class));for (Bus bus1 : listAutomobiles) {if(bus1.getBrand().equals(bus.getBrand())&&bus1.getSeat()==bus.getSeat()){return bus1;}}} catch (SQLException e) {e.printStackTrace();}return null;}@Overridepublic Automobile selectOne(Car car) {String sql="select * from automobile;";try {List<Car> listAutomobiles=queryRunner.query(sql, new BeanListHandler<Car>(Car.class));for (Car car1 : listAutomobiles) {if(car1.getBrand().equals(car.getBrand())&&car1.getType().equals(car.getType())){return car1;}}} catch (SQLException e) {e.printStackTrace();}return null;}
}

6、服务层 AutomobileService 接口

package cn.automobile.service;import cn.automobile.entity.Automobile;
import cn.automobile.entity.Bus;
import cn.automobile.entity.Car;public interface AutomobileService {//查busAutomobile selectBus(Bus bus);//查carAutomobile selectCar(Car car);
}

7、服务层 AutomobileServiceImpl 实现类

package cn.automobile.service.impl;import cn.automobile.dao.AutomobileDao;
import cn.automobile.dao.Impl.AutomobileDaoImpl;
import cn.automobile.entity.Automobile;
import cn.automobile.entity.Bus;
import cn.automobile.entity.Car;
import cn.automobile.service.AutomobileService;public class AutomobileServiceImpl implements AutomobileService {AutomobileDao autoD=new AutomobileDaoImpl();@Overridepublic Automobile selectBus(Bus bus) {return autoD.selectOne(bus);}@Overridepublic Automobile selectCar(Car car) {return autoD.selectOne(car);}}

8、视图层:租车测试AutomobileMgr类

package cn.automobile.view;import java.util.Scanner;import cn.automobile.entity.Automobile;
import cn.automobile.entity.Bus;
import cn.automobile.entity.Car;
import cn.automobile.service.AutomobileService;
import cn.automobile.service.impl.AutomobileServiceImpl;public class AutomobileMgr {public static void main(String[] args) {Scanner sc=new Scanner(System.in);String brand=null,type=null;int seat=0;double money = 0;Automobile automobile=null;AutomobileService autoS=new AutomobileServiceImpl();System.out.println("********欢迎光临租赁公司********\n");System.out.println("请选择汽车类型:1、轿车\t2、客车");int autoType=sc.nextInt();if(autoType==1){System.out.println("请选择轿车品牌:1、宝马\t2、别克");brand=(sc.nextInt()==1)?"宝马":"别克";if(brand=="宝马"){System.out.println("请选择轿车型号:1、X6\t2、550i");type=(sc.nextInt()==1)?"X6":"550i";}else if(brand=="别克"){System.out.println("请选择轿车型号:1、林荫大道\t2、GL8");type=(sc.nextInt()==1)?"林荫大道":"GL8";}}else if(autoType==2){System.out.println("请选择客车品牌:1、金杯\t2、金龙");brand=(sc.nextInt()==1)?"金杯":"金龙";System.out.println("请选择需要的座位数:1、16座\t2、34座");seat=(sc.nextInt()==1)?16:34;}System.out.println("请选择租赁天数:");int days=sc.nextInt();if (seat==0) {Car car=new Car();car.setBrand(brand);car.setType(type);automobile=autoS.selectCar(car);	money=car.calRent(days,automobile.getDayRent());		}else if(seat!=0) {Bus bus=new Bus();bus.setBrand(brand);bus.setSeat(seat);automobile=autoS.selectBus(bus);money=bus.calRent(days,automobile.getDayRent());		}
//		System.out.println(automobile);System.out.println("租车成功!请按照"+automobile.getNumberPlate()+"车牌号取车!租金为:"+money+"元");}}

效果展示


       码文不易,本篇文章就介绍到这里,如果想要学习更多Java系列知识,请关注博主,博主带你零基础学习Java知识。与此同时,对于日常生活有困扰的朋友,欢迎阅读我的第四栏目:《国学周更—心性养成之路》,学习技术的同时,我们也注重了心性的养成。


http://www.ppmy.cn/news/13.html

相关文章

Python 面向对象简介

什么是面向对象&#xff1f; 面向对象是一种编程思想&#xff0c;在开发过程中关注的不是解决问题的步骤和过程&#xff0c;而是参与解决问题的对象和它们具备的行为。 01 面向过程和面向对象的区别 1、面向过程 面向过程在开发过程中关注的是解决问题的步骤和过程&#xf…

只会 Python 不行,不会 Python 万万不行

当下的环境大家有目共睹&#xff0c;未来一段时间情况如何&#xff0c;想必不少人心里也清楚&#xff0c;技术人走到中年&#xff0c;难免会焦虑&#xff0c;职场上干得不爽&#xff0c;但是跳槽也不容易&#xff0c;加上不少企业裁员&#xff0c;换个满意的工作更是难上加难。…

Promise 的状态, promise 指定多个成功/失败回调函数,都会调用吗?

实例对象promise中的一个属性 PromiseState pending 变为 resolved/fullfilled pending 变为 rejected 注意 对象的状态不受外界影响 只有这两种&#xff0c;且一个 promise 对象只能改变一次 一旦状态改变&#xff0c;就不会再变&#xff0c;任何时候都可以得到这个结果 无论…

美团应届生面试第一问:Object o = new Object()占用多少字节?

文章目录工具查看内存分配Java内存模型访问对象方式GC为什么Survivor要分为两个区域&#xff08;S0和S1&#xff09;&#xff1f;Survivor 为什么不分更多块呢&#xff1f;对象的生命周期小知识工具查看内存分配 Object o new Object();占用多少字节&#xff0c;我们借助open…

PHP转Go,框架选什么?

文章目录内功心法PHP转Go&#xff0c;优选哪个框架&#xff1f;为什么&#xff1f;为什么不火&#xff1f;GoFrame特点优势&#xff1a;劣势&#xff1a;框架选型谁适合用GoFrame谁不适合用GoFrameGoFrame框架设计思想开发流程从0到1核心步骤总结视频一起学习这是一期会引起广泛…

进程与信号(三)

目录 一、前言 二、Signals 1、Signal Handling&#xff08;ctrlc.c&#xff09; 2、Sending Signals &#xff08;1&#xff09;alarm.c &#xff08;2&#xff09;A Robust Signals Interface &#xff08;3&#xff09;ctrlc2.c 3、Signal Sets &#xff08;1&…

ThinkPHP5文档学习——配置

文章目录一、配置目录二、配置格式PHP数组定义其它格式的支持二级配置三、配置加载惯例配置应用配置拓展配置场景配置四、读取配置参数五、动态配置设置配置参数六、独立配置独立配置文件V5.0.1版本已经废除该写法自动读取扩展配置七、配置作用域八、环境变量配置一、配置目录 …

C语言—指针进阶(详解篇)

目录 1.字符指针 1.1字符指针定义 1.2 字符指针用法 2.指针数组 2.1 指针数组定义及使用 3.数组指针 3.1 数组指针定义 3.2 &数组名和数组名 3.3 数组指针的基本用法 4. 数组参数、指针参数 5. 函数指针 5.1 函数指针定义既基本使用 5.2 有趣的代码 6. 函…