DAO模式

JDBC封裝java

 爲何進行JDBC封裝mysql

  

  

 實現JDBC封裝sql

  

  

  

  

  

  

  

 DAO模式的組成數據庫

  

  

package cn.jbit.epet.entity;

import java.util.Date;

public class Pet {
    private int id; // 寵物id
    private int masterId; // 主人id
    private String name; // 暱稱
    private int typeId; // 類型id
    private int health; // 健康值
    private int love; // 親密度
    private Date adoptTime; // 領養時間
    private String status; // 狀態

    public Pet() {
    }

    public Pet(int id, int masterId, String name, int typeId, int health,
            int love, Date adoptTime, String status) {
        super();
        this.id = id;
        this.masterId = masterId;
        this.name = name;
        this.typeId = typeId;
        this.health = health;
        this.love = love;
        this.adoptTime = adoptTime;
        this.status = status;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public int getMasterId() {
        return masterId;
    }

    public void setMasterId(int masterId) {
        this.masterId = masterId;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getTypeId() {
        return typeId;
    }

    public void setTypeId(int typeId) {
        this.typeId = typeId;
    }

    public int getHealth() {
        return health;
    }

    public void setHealth(int health) {
        this.health = health;
    }

    public int getLove() {
        return love;
    }

    public void setLove(int love) {
        this.love = love;
    }

    public Date getAdoptTime() {
        return adoptTime;
    }

    public void setAdoptTime(Date adoptTime) {
        this.adoptTime = adoptTime;
    }

    public String getStatus() {
        return status;
    }

    public void setStatus(String status) {
        this.status = status;
    }
}
實體類
package cn.jbit.epet.dao;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class BaseDao {
    private String driver = "com.mysql.jdbc.Driver"; // 數據庫驅動字符串
    private String url = "jdbc:mysql://localhost:3306/epet"; // 數據庫鏈接字符串
    private String user = "epetadmin"; // 數據庫用戶名
    private String password = "0000"; // 數據庫密碼
    Connection conn = null;

    // 1.打開數據庫
    public Connection getConnection() {
        try {
            Class.forName(driver);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
        try {
            conn = DriverManager.getConnection(url, user, password);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return conn;
    }

    // 2.關閉全部資源
    public void closeAll(Connection conn, PreparedStatement stmt, ResultSet rs) {
        if (rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (stmt != null) {
            try {
                stmt.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    // 3.增、刪、改通用方法
    public int executeUpdate(String sql, Object[] param) {
        int num = 0; // 影響行數
        conn = this.getConnection();
        PreparedStatement stmt = null;
        try {
            stmt = conn.prepareStatement(sql);
            // 爲參數賦值
            if (param != null) {
                for (int i = 0; i < param.length; i++) {
                    stmt.setObject(i + 1, param[i]);
                }
            }
            // 執行sql語句
            num = stmt.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            this.closeAll(conn, stmt, null);
        }
        return num;
    }
}
數據庫工具類
package cn.jbit.epet.dao;

import java.util.List;

import cn.jbit.epet.entity.Pet;

public interface PetDao {
    int save(Pet pet);

    int del(Pet pet);

    int update(Pet pet);

    Pet getByName(String name);

    List<Pet> findByName(String name);

    List<Pet> findByType(String type);
}
DAO接口
package cn.jbit.epet.dao.impl;

import java.util.List;

import cn.jbit.epet.dao.BaseDao;
import cn.jbit.epet.dao.PetDao;
import cn.jbit.epet.entity.Pet;

public class PetDaoMySQLImpl extends BaseDao implements PetDao {

    @Override
    public int save(Pet pet) {
        return 0;
    }

    @Override
    public int del(Pet pet) {
        return 0;
    }

    @Override
    public int update(Pet pet) {
        String sql = "update dog set status=0 where id=?";
        Object[] param = { pet.getId() };
        int result = this.executeUpdate(sql, param);
        return result;
    }

    @Override
    public Pet getByName(String name) {
        return null;
    }

    @Override
    public List<Pet> findByName(String name) {
        return null;
    }

    @Override
    public List<Pet> findByType(String type) {
        return null;
    }

}
DAO實現類
package cn.jbit.epet.manager;

import cn.jbit.epet.dao.PetDao;
import cn.jbit.epet.dao.impl.PetDaoMySQLImpl;
import cn.jbit.epet.entity.Pet;

public class Test {
    public static void main(String[] args) {
        PetDao petDao = new PetDaoMySQLImpl();
        Pet pet = new Pet();
        pet.setId(1);
        int result = petDao.update(pet);
        if (result > 0) {
            System.out.println("狗狗信息更新成功!");
        } else {
            System.out.println("狗狗信息更新失敗!");
        }
    }
}
測試類

Properties類ide

  

  

  

相關文章
相關標籤/搜索