收藏此站 联系我们 网站
当前位置:首页» 行业新闻 » 【建站服务】宝鸡爱采购会员/58同城会员账户/百度竞价开户/百家号注册运营/推广公司网站-网站营销全网推广-域名申请

【建站服务】宝鸡爱采购会员/58同城会员账户/百度竞价开户/百家号注册运营/推广公司网站-网站营销全网推广-域名申请

作者: 风兰 . 阅读量: 3 . 发表时间:2022-09-21 05:28:38

网站建设

上往建站提供服务器空间服务商百度快照排名网站托管百度推广运营,致力于设计外包服务与源代码定制开发360推广搜狗推广,增加网站的能见度及访问量提升网络营销的效果,主营:网站公司,百度推广公司电话,官网搭建服务,网站服务企业排名,服务器空间,英文域名等业务,专业团队服务,效果好。


宝鸡爱采购会员/58同城会员账户/百度竞价开户/百家号注册运营/推广公司网站-网站营销全网推广

网站建设.png

DAO 模式

DAO (DataAccessobjects 数据存取对象)是指位于业务逻辑和持久化数据之间实现对持久化数据的访问。通俗来讲,就是将数据库操作都封装起来。

对外提供相应的接口

在面向对象设计过程中,有一些"套路”用于解决特定问题称为模式。

DAO 模式提供了访问关系型数据库系统所需操作的接口,将数据访问和业务逻辑分离对上层提供面向对象的数据访问接口。

从以上 DAO 模式使用可以看出,DAO 模式的优势就在于它实现了两次隔离。

  • 1、隔离了数据访问代码和业务逻辑代码。业务逻辑代码直接调用DAO方法即可,完全感觉不到数据库表的存在。分工明确,数据访问层代码变化不影响业务逻辑代码,这符合单一职能原则,降低了藕合性,提高了可复用性。

  • 2、隔离了不同数据库实现。采用面向接口编程,如果底层数据库变化,如由 MySQL 变成 Oracle 只要增加 DAO 接口的新实现类即可,原有 MySQ 实现不用修改。这符合 "开-闭" 原则。该原则降低了代码的藕合性,提高了代码扩展性和系统的可移植性。

一个典型的DAO 模式主要由以下几部分组成。

  •  1、DAO接口: 把对数据库的所有操作定义成抽象方法,可以提供多种实现。

  •  2、DAO 实现类: 针对不同数据库给出DAO接口定义方法的具体实现。

  •  3、实体类:用于存放与传输对象数据。

  •  4、数据库连接和关闭工具类: 避免了数据库连接和关闭代码的重复使用,方便修改。

DAO 接口:

public interface PetDao {    /**
     * 查询所有宠物
     */    List<Pet> findAllPets() throws Exception;}

DAO 实现类:

public class PetDaoImpl extends BaseDao implements PetDao {    /**
     * 查询所有宠物
     */    public List<Pet> findAllPets() throws Exception {        Connection conn=BaseDao.getConnection();        String sql="select * from pet";        PreparedStatement stmt= conn.prepareStatement(sql);        ResultSet rs=    stmt.executeQuery();        List<Pet> petList=new ArrayList<Pet>();        while(rs.next()) {            Pet pet=new Pet(                    rs.getInt("id"),                    rs.getInt("owner_id"),                    rs.getInt("store_id"),                    rs.getString("name"),                    rs.getString("type_name"),                    rs.getInt("health"),                    rs.getInt("love"),                    rs.getDate("birthday")                    );                petList.add(pet);        }        BaseDao.closeAll(conn, stmt, rs);        return petList;    }}

宠物实体类(里面get/set方法就不列出了)

public class Pet {    private Integer id;    
    private Integer ownerId;    //主人ID    private Integer storeId;    //商店ID    private String name;    //姓名    private String typeName;    //类型    private int health;    //健康值    private int love;    //爱心值    private Date birthday;    //生日}

连接数据库

public class BaseDao {    private static String driver="com.mysql.jdbc.Driver";    private static String url="jdbc:mysql://127.0.0.1:3306/epet";    private static String user="root";    private static String password="root";        static {            try {                Class.forName(driver);            } catch (ClassNotFoundException e) {                e.printStackTrace();            }        }        
    public static Connection getConnection() throws SQLException {        return DriverManager.getConnection(url, user, password);    
    }    
    public static void closeAll(Connection conn,Statement stmt,ResultSet rs) throws SQLException {        if(rs!=null) {            rs.close();        }        if(stmt!=null) {            stmt.close();        }


      if(rs!=null) {

            rs.close();

        }

        if(stmt!=null) {

            stmt.close();

        }

        if(conn!=null) {

            conn.close();

        }

    }

    


    public int executeSQL(String preparedSql, Object[] param) throws ClassNotFoundException {

        Connection conn = null;

        PreparedStatement pstmt = null;

        /* 处理SQL,执行SQL */

        try {

            conn = getConnection(); // 得到数据库连接

            pstmt = conn.prepareStatement(preparedSql); // 得到PreparedStatement对象

            if (param != null) {

                for (int i = 0; i < param.length; i++) {

                    pstmt.setObject(i + 1, param[i]); // 为预编译sql设置参数

                }

            }

        ResultSet num = pstmt.executeQuery(); // 执行SQL语句

        } catch (SQLException e) {

            e.printStackTrace(); // 处理SQLException异常

        } finally {

            try {

                BaseDao.closeAll(conn, pstmt, null);

            } catch (SQLException e) {    

                e.printStackTrace();

            }

        }

        return 0;

    }

    

}

哈哈哈哈哈。。。呃~

   哈哈哈哈哈。。。呃~


  248***8117@qq.com


   参考地址


4年前 (2018-05-07)

   TiAmo


  576***486@qq.com


22

MySQL 8.0 以上版本:


驱动包版本 mysql-connector-java-8.0.12.jar。


数据库 URL 需要声明是否使用 SSL 安全验证及指定服务器上的时区:


static final String DB_URL = jdbc:mysql://localhost:3306/runoob?useSSL=false&serverTimezone=UTC;

conn = DriverManager.getConnection(DB_URL,USER,PASS);

原本的驱动器是:


Class.forName("com.mysql.jdbc.Driver");

在 IDEA 里面提示是: Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary


意思是说原本的驱动器不赞成 或者 是废弃了,自动换成了新的驱动器 com.mysql.cj.jdbc.Driver


Class.forName("com.mysql.cj.jdbc.Driver");

TiAmo

   TiAmo


  576***486@qq.com


4年前 (2018-08-23)

   this


  tli***1990@gmail.com


   参考地址


17

在 JDBC4.0 之前,连接数据库的时候,通常会用 Class.forName("com.mysql.jdbc.Driver") 这句先加载数据库相关的驱动,然后再进行获取连接等的操作。而 JDBC4.0 之后不需要 Class.forName 来加载驱动,直接获取连接即可,这里使用了 Java 的SPI扩展机制来实现。


this

   this


  tli***1990@gmail.com


   参考地址


3年前 (2019-05-05)

   Nomoku


  222***4847@qq.com


   参考地址


12

运行程序时抛出异常:


Caused by: java.sql.SQLException: The server time zone value '�й���׼ʱ��' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

解决办法:



jdbcUrl=jdbc:mysql://localhost:3306/spring

后面加上:


jdbcUrl=jdbc:mysql://localhost:3306/spring?serverTimezone=UTC  

但如果你的 jdbcUrl 类似下面:


jdbcUrl=jdbc:mysql://localhost:3306/spring?ser


宝鸡爱采购会员/58同城会员账户/百度竞价开户/百家号注册运营/推广公司网站-网站营销全网推广


上往建站提供搭建网站域名注册官网备案服务网店详情页设计企业网店专业网络店铺管理运营全托管公司咨询电话,服务器空间,微信公众号托管网页美工排版,致力于域名申请竞价托管软文推广全网营销,提供标准级专业技术保障,了却后顾之忧,主营:虚拟主机网站推广百度竞价托管网站建设上网建站推广服务网络公司有哪些等业务,专业团队服务,效果好。

服务热线:400-111-6878 手机微信同号:18118153152(各城市商务人员可上门服务)


关键词:网站建设,企业网站,网站制作,网页设计,高端网站建设,企业网站制作,网页制作,制作网站,网站设计,高端网页设计,高端网站设计,做网站,自适应网站

全国服务热线
18114747181
二维码
手机端二维码
上往建站
地址:全国各地都有驻点商务 |  网站建设上往建站
在线咨询QQ:1120768800
 
QQ在线咨询
售前咨询热线
18114747181
营销顾问
营销顾问
售后服务热线
400-000-1116
售后服务
售后服务