今天分享一个我做的使用DAO设计模式实现的商品增删改查功能的小项目,首先我们需要了解什么是DAO模式,他有什么用呢?
什么是DAO?
DAO(Data Access Object,数据访问对象),主要的功能就是用于进行数据操作的,在程序的标准开发架构中
整个DAO中实际上都是以接口为操作标准的,即:客户端依靠DAO实现的接口进行操作,而服务端要将接口进行具体的实现,DAO由以下几个部分组成:
-
DatabaseConnection:专门负责数据库的打开与关闭操作的类;
-
VO:主要由属性、setter、getter方法组成,VO类中的属性与表中的字段对应,每一个VO类的对象都表示表中的每一条记录;
-
DAO:主要定义操作的接口,定义一系列数据库的原子性操作,例如:增加、修改、删除、按ID查询等;
-
Impl:DAO接口的真实实现类,完成具体的数据库操作,但是不负责数据库的打开和关闭;
-
Proxy:代理实现类,主要完成数据库的打开和关闭并且调用真实实现类对象的操作;
-
Factory:工厂类,通过工厂类取得一个DAO的实例化对象。
属于数据层的操作。
整个DAO模式包含的东西很多,从中不难看出,DAO操作模式主要是实现与数据库连接的一些操作,与以往不同的是,他将许多功能都模块化了,有的类专门负责数据库的打开与关闭、有的类专门负责对数据库的操作、有的类则是专门表示数据库中的对象,各司其职。
这样做的好处就是可以让代码的耦合性降低,便于后期的拓展和维护,比如:我现在需要切换一个数据库,那么我只需要在专门负责数据库连接的类中修改数据库的名字、密码等等就可以了,其他地方我不需要再做更改。
项目主体:
在初步了解DAO之后,我们就看一下功能是怎么实现的
DAO部分:
首先我们需要一个专门负责数据库开关的类DatabaseConnection:
package com.lzx.dbc;
import java.sql.Connection;
import java.sql.DriverManager;
public class DatabaseConnection {
//定义数据库驱动、数据库连接URL、数据库用户名、数据库密码
public static final String DBDRIVER="com.mysql.cj.jdbc.Driver";
public static final String DBURL="jdbc:mysql://localhost:3306/vehicleproject?serverTimezone=UTC&useSSL=false";
public static final String DBUSER="root";
public static final String DBPASSWORD="lzx0205";
//定义表示连接的Connection对象
private Connection conn=null;
public Connection getConn() {
return this.conn;
}
//在空参构造中定义建立数据库连接的语句,这样在类加载的时候就会自动加载
public DatabaseConnection() throws Exception{
try{
Class.forName(DBDRIVER);//加载数据库驱动
this.conn= DriverManager.getConnection(DBURL,DBUSER,DBPASSWORD);//返回Connection对象
}catch (Exception e){
throw e;
}
}
//定义关闭语句,防止资源的占用。
public void close() throws Exception{
if(this.conn!=null){
try{
this.conn.close();
}catch (Exception e){
throw e;
}
}
}
}
其次是代表数据库中表格的VO,这里注意,可以有很多表,所以VO实际上指的是包名:
package com.lzx.VO;
public class tbl_Goods {
private String goodsId;
private String goodsName;
private String goodsPrice;
private String goodsColor;
private String goodsNum;
private String goodsImg;
private String goodsave;
//构造方法:
public tbl_Goods(){
}
public tbl_Goods(String goodsId, String goodsName, String goodsPrice, String goodsColor, String goodsNum, String goodsImg, String goodsave) {
this.goodsId = goodsId;
this.goodsName = goodsName;
this.goodsPrice = goodsPrice;
this.goodsColor = goodsColor;
this.goodsNum = goodsNum;
this.goodsImg = goodsImg;
this.goodsave = goodsave;
}
//set、get方法
public String getGoodsId() {
return goodsId;
}
public void setGoodsId(String goodsId) {
this.goodsId = goodsId;
}
public String getGoodsName() {
return goodsName;
}
public void setGoodsName(String goodsName) {
this.goodsName = goodsName;
}
public String getGoodsPrice() {
return goodsPrice;
}
public void setGoodsPrice(String goodsPrice) {
this.goodsPrice = goodsPrice;
}
public String getGoodsColor() {
return goodsColor;
}
public void setGoodsColor(String goodsColor) {
this.goodsColor = goodsColor;
}
public String getGoodsNum() {
return goodsNum;
}
public void setGoodsNum(String goodsNum) {
this.goodsNum = goodsNum;
}
public String getGoodsImg() {
return goodsImg;
}
public void setGoodsImg(String goodsImg) {
this.goodsImg = goodsImg;
}
public String getGoodsave() {
return goodsave;
}
public void setGoodsave(String goodsave) {
this.goodsave = goodsave;
}
@Override
public String toString() {
return "tbl_Goods{" +
"goodsId='" + goodsId + '\'' +
", goodsName='" + goodsName + '\'' +
", goodsPrice='" + goodsPrice + '\'' +
", goodsColor='" + goodsColor + '\'' +
", goodsNum='" + goodsNum + '\'' +
", goodsImg='" + goodsImg + '\'' +
", goodsave='" + goodsave + '\'' +
'}'+"\n";
}
}
可以看到,这里包含了商品ID、商品名称等等属性,也就是说,这个类的一个实例对象就是一个商品。
接下来我们需要定义一个接口,在这个接口中我们需要先声明一下需要什么方法:
package com.lzx.DAO;
import com.lzx.VO.tbl_Goods;
import java.util.List;
public interface IGoodsDAO {
//创建数据增加方法,返回是否增加成功的结果
boolean doCreate(tbl_Goods goods) throws Exception;
//创建查询方法,查询全部数据
List<tbl_Goods> findAllGoods() throws Exception;
List<tbl_Goods> findAllByName(String keyword) throws Exception;
//创建查询单个商品的方法,根据商品的id查询,返回单个商品
tbl_Goods findByID(String id)throws Exception;
//创建删除商品的方法,根据商品id删除
int deleteById(String id) throws Exception;
//创建修改商品的方法,传入一个新的商品信息代替
int setGoods(tbl_Goods goods) throws Exception;
//创建修改商品库存的方法,根据商品的id确定商品,然后修改。
int setGoodsaveById(String id,String save) throws Exception;
}
然后根据这个接口写出实现类:
package com.lzx.DAO.Impl;
import com.lzx.DAO.IGoodsDAO;
import com.lzx.VO.tbl_Goods;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
public class GoodsDAOImpl implements IGoodsDAO {
private Connection conn=null;
private PreparedStatement ps=null;
public GoodsDAOImpl(Connection conn) {