zoukankan      html  css  js  c++  java
  • 标准 mysql 数据库 jdbc 的两种写法 懒汉式 和 饿汉式

    饿汉式写法如下:  建议使用

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    
    public class DataBaseConnection {
        private static final String DBDRIVER = "org.gjt.mm.mysql.Driver";
        private static final String DBURL = "jdbc:mysql://localhost:3306/test";
        private static final String DBUSER = "root";
        private static final String PASSWORD = "admin";
        public Connection conn;
    
        //饿汉式数据库连接
        public Connection getConnection() {
            try {
                if (conn == null && conn.isClosed())
                    Class.forName(DBDRIVER);
                conn = DriverManager.getConnection(DBURL, DBUSER, PASSWORD);
            } catch (ClassNotFoundException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return conn;
        }
        public void close(){
            if(conn != null){
                try {
                    this.conn.close();
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
    }

    懒汉式

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    
    public class DatabaseConnection {
        private static final String DBDRIVER = "org.gjt.mm.mysql.Driver";
        private static final String DBURL = "jdbc:mysql://localhost:3306/test";
        private static final String DBUSER = "root";
        private static final String PASSWORD = "admin";
        private Connection conn = null;
    
        // 如果要实例化本类对象,实际上就是为了取得数据库连接,那么就把连接过程交给构造方法
        public DatabaseConnection() {
            try {
                Class.forName(DBDRIVER);
                this.conn = DriverManager.getConnection(DBURL, DBUSER, DBPASSWORD);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    
        public Connection getConnection() {
            return this.conn;
        }
    
        public void close() {
            if (this.conn != null) {
                try { // 关闭时几乎不会有问题
                    this.conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
  • 相关阅读:
    由u盘安装Ubuntu引出的事件
    初试Ubuntu
    从error 中学习
    快手一面:牛客:字符串左移
    快手一面:Leetcode:最小栈
    十三、线程池
    十二、windows临界区、其他各种mutex互斥量
    十一、std::async深入
    LeetCode(703):找出数据流中的第K大元素
    LeetCode(1003):检查替换后的字符串
  • 原文地址:https://www.cnblogs.com/arkia123/p/2736499.html
Copyright © 2011-2022 走看看