JDBC 连接数据库
admin
2023-05-27 08:01:36
0

一、通过Driver接口直接连接

/**
 * 通过Driver获取Connection
 * @return
 */
public Connection getConnectionByDriver() throws Exception{
    String driverClass = "com.mysql.jdbc.Driver";
    String url = "jdbc:mysql:///hdz";
    String user = "root";
    String password = "123456";
    Driver driver = new com.mysql.jdbc.Driver();
    Properties info = new Properties();
    info.setProperty("driverClass", driverClass);
    info.setProperty("user", user);
    info.setProperty("password", password);
    Connection connection = driver.connect(url, info);
    return connection;
}

二、通过DriverManager直接连接

/**
 * 通过DriverManager获取Connection 
 * @return
 * @throws Exception
 */
public Connection getConnectionByDriverManager() throws Exception{
    String url = "jdbc:mysql:///hdz";
    String user = "root";
    String password = "123456";
    Class.forName("com.mysql.jdbc.Driver");
    Connection connection = DriverManager.getConnection(url, user, password);
    return connection;
}
/**
    * 通过把参数写在配置文件的方式获取Connection
    * @return
    * @throws Exception
*/
public Connection getConectionByProperties() throws Exception{
	InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("jdbc.properties");
	Properties info = new Properties();
	info.load(inputStream);
	String url = info.getProperty("url");
	Class.forName("com.mysql.jdbc.Driver");
	Connection connection = DriverManager.getConnection(url, info);
	return connection;
}
url=jdbc:mysql:///hdz
user=root
password=123456

三、通过DBCP数据源连接

@Test
public void testDbcp() throws Exception {
    final BasicDataSource basicDataSource = new BasicDataSource();
    basicDataSource.setDriverClassName("com.mysql.jdbc.Driver");
    basicDataSource.setUrl("jdbc:mysql:///hdz");
    basicDataSource.setUsername("root");
    basicDataSource.setPassword("123456");
    basicDataSource.setInitialSize(2);
    basicDataSource.setMaxActive(2);
    basicDataSource.setMinIdle(2);
    basicDataSource.setMaxWait(2000);
    Connection connection1 = basicDataSource.getConnection();
    System.out.println(connection1);
    Connection connection2 = basicDataSource.getConnection();
    System.out.println(connection2);
    new Thread(){
        @Override
        public void run() {
            Connection connection3;
            try {
                connection3 = basicDataSource.getConnection();
                System.out.println(connection3);
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }.start();
    Thread.sleep(3000);
    connection2.close();
}

或者通过配置文件,BasicDatasourceFactory工厂方式

private DbcpDataSource() {
    Properties info = new Properties();
    InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("dbcp.properties");
    try {
        info.load(inputStream);
        dataSource = BasicDataSourceFactory.createDataSource(info);
    } catch (IOException e) {
        e.printStackTrace();
    } catch (Exception e) {
        e.printStackTrace();
    }
}
dbcp.properties

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:///hdz
username=root
password=123456

initialSize=5
maxActive=10
minIdle=5
maxWait=5000

四、通过C3P0数据源连接

public class C3p0DataSourceUtils {
private DataSource dataSource = null;
private static C3p0DataSourceUtils instance = new C3p0DataSourceUtils();
private C3p0DataSourceUtils(){
    dataSource = new ComboPooledDataSource("intergalactoApp");
}
public static C3p0DataSourceUtils newInstance(){
    return instance;
}
public Connection getConnection() {
    try {
        return dataSource.getConnection();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return null;
    }
}
c3p0-config.xml



  
   
    1
    1
    1
    1
    1000
    
    10 
    5
com.mysql.jdbc.Driver
jdbc:mysql:///hdz
root
123456
  


相关内容

热门资讯

中构建筑取得钢结构厂房用可伸缩... 国家知识产权局信息显示,中构建筑有限公司取得一项名为“一种钢结构厂房用可伸缩式抗风支撑杆”的专利,授...
西安光机所破解传统光纤在中长波... 中新网西安5月20日电 (记者 阿琳娜)记者20日从西安光机所获悉,该所郭海涛研究员团队成功研制出国...
北约秘书长“和稀泥”:美国在欧... 【文/观察者网 张菁娟】美国五角大楼日前“取消4000名美军驻波部署”的消息触动了波兰的神经,波兰官...
联想面向广大开发者与用户提供1... 5月19日晚,联想集团执行副总裁兼中国区总裁刘军开启天禧AI Skills(技能集)共创“苍穹计划”...
从“卡脖子”到“掰手腕”:中俄... 人民网记者 张齐 第十届中俄博览会上,人流穿梭。有的展台前载歌载舞,有的展台前分发美食,在几家黑龙江...
原创 一... 本文来源于海潮天下(Marine Biodiversity) 欢迎微信搜索“海潮天下”,关注全球环...
太阳“发脾气”地球会怎样?中欧... “微笑”卫星 据中国科学院消息,中欧联合研制的太阳风-磁层相互作用全景成像卫星(英文缩写SMILE,...
原创 野... 本文来源于海潮天下(Marine Biodiversity) 欢迎微信搜索“海潮天下”,关注全球环...
腾讯亮相2026中国网络文明大... 5月19日至20日,以“文明网络空间 昂扬奋进力量”为主题的2026年中国网络文明大会在广西南宁举行...
胡锡进:中俄罕见同时发两份联合... 中国与俄罗斯周三晚间同时发布两项联合声明,这非常罕见,举世瞩目。在第一项联合声明中,中俄两国宣示进一...