使用DAO模式实现商品增删改查

本文介绍了使用DAO设计模式实现商品的增删改查功能。详细讲解了DAO模式的组成部分,如DatabaseConnection、VO、DAO接口及其实现类、Proxy和Factory,并展示了如何通过工厂类获取DAO对象来操作数据库。在项目实现部分,包括DAO接口定义、实现类编写、Servlet处理请求以及JSP展示界面,实现了完整的商品管理功能。
摘要由CSDN通过智能技术生成

今天分享一个我做的使用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) {
        s
  • 6
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力回答你的问题。首先,MVC是一种常见的软件架构模式,它将应用程序分为三个核心部分:模型、视图和控制器。DAO是数据访问对象的缩写,它是一种数据访问设计模式,用于将数据访问逻辑与业务逻辑分离。 对于一个web购物系统,我们可以按照以下步骤进行设计和实现: 1. 模型层:模型层负责处理数据的存储和管理。我们可以使用数据库来存储商品信息、订单信息等。使用DAO设计模式,我们可以创建一个商品DAO和一个订单DAO,用于处理数据的增、删、改、查等操作。同时,我们也需要定义商品和订单的数据模型,以便在控制器和视图中进行使用。 2. 视图层:视图层负责呈现数据给用户。我们可以使用HTML、CSS和JavaScript等技术来设计和实现网页界面。在实现网页界面时,我们可以使用模板引擎来动态生成HTML代码,以便根据数据模型中的内容来呈现不同的页面。 3. 控制器层:控制器层负责处理用户的请求和业务逻辑。我们可以使用PHP、Java或其他编程语言来实现控制器层。在控制器层中,我们可以调用商品DAO和订单DAO中的方法来访问数据库,并根据用户的请求来实现不同的业务逻辑。例如,当用户提交订单时,我们可以从商品DAO中查询商品信息,并将订单信息插入到订单DAO中。 以上就是使用MVC+DAO设计模式设计实现一个web购物系统的大致思路。当然,在实际开发中,还需要考虑安全性、性能优化、用户体验等方面的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值