获取数据库连接

1.JDBC概述

1.1数据的持久化持久化(persistence):

  • 把数据保存到可掉电式存储设备中以供之后使用。大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以”固化”,而持久化的实现过程大多通过各种关系数据库来完成。
  • 持久化的主要应用是将内存中的数据存储在关系型数据库中,当然也可以存储在磁盘文件、XML数据文件中。

1.2 Java中的数据存储技术在Java中

数据库存取技术可分为如下几类:

  • JDBC直接访问数据库

  • JDO (Java Data Object )技术

  • 第三方O/R工具,如Hibernate, Mybatis等

    JDBC是java访问数据库的基石,JDO、Hibernate、MyBatis等只是更好的封装了JDBC

2.JDBC介绍

  • JDBC( Java Database Connectivity)是一个独立于特定数据库管理系统、通用的SQL数据库存取和操作的公共接口(一组API),定义了用来访问数据库的标准Java类库,(java.sql,javax.sql)使用这些类库可以以一种标准的方法、方便地访问数据库资源。
  • JDBC为访问不同的数据库提供了一种统一的途径,为开发者屏蔽了一些细节问题。
  • JDBC的目标是使Java程序员使用JDBC可以连接任何提供了JDBC驱动程序的数据库系统,这样就使得程序员无需 对特定的数据库系统的特点有过多的了解,从而大大简化和加快了开发过程。

3. JDBC体系结构

3.1 JDBC接口(API)包括两个层次:

  • 面向应用的API:Java API,抽象接口,供应用程序开发人员使用(连接数据库,执行SQL语句,获得结果)

  • 面向数据库的API:Java Driver API,供开发商开发数据库驱动程序用

5.获取数据库的连接方式

方式一

// 导包
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
import org.junit.Test;

@Test
public void testConnection() throws Exception {
//		获取Driver的实现类对象
		Driver driver = new com.mysql.jdbc.Driver();
    //url地址解析 
//		1.jdbc:mysql:协议
//		2.localhost:ip地址
//		3.3306:默认mysql端口号
//		4.test:数据库名
    
    
		String url = "jdbc:mysql://localhost:3306/test";
		
//		将用户名和密码封装到Properties中
		Properties info = new Properties();
		info.setProperty("user", "root");
		info.setProperty("password", "123456");
		
		Connection con =  driver.connect(url, info);
		System.out.println(con);
} 

方式二

  • 相较于方式一,方式 二使用反射来实例化driver对象
  • 优点:不在代码中体现第三方数据库的API,体现了面向接口编程思想
//	方式二: 使用反射来实例化driver对象
	@Test  
	public void testTwoConnection() throws Exception {
//		1.获取Driver的实现类对象,使用反射
		Class claz = Class.forName("com.mysql.jdbc.Driver");
		Driver driver = (Driver)claz.newInstance();
		
//		2.提供需要连接的数据库
		String url = "jdbc:mysql://localhost:3306/test";
		
//		3.提供需要链接的用户名和密码
		Properties info = new Properties();
		info.setProperty("user", "root");
		info.setProperty("password", "123456");
		
//		4.获取链接
		Connection conn = driver.connect(url, info);
		System.out.println(conn);
		
	}

方式三

  • 相较于方式二,方式三除了使用反射来实例化driver对象,还使用 DriverManager注册驱动,替换了driver
	@Test
	public void testThreeConnection() throws Exception {
		
		//2.实例化driver
		Class clazz = Class.forName("com.mysql.jdbc.Driver");
		Driver driver = (Driver)clazz.newInstance();
		
		//1.数据库连接的基本要素
		String url = "jdbc:mysql://localhost:3306/test";
		String user = "root";
		String password = "123456";
		
		//3.注册驱动
		DriverManager.registerDriver(driver);
		
		//4.获取链接
		Connection conn = DriverManager.getConnection(url, user,password);
		System.out.println(conn);
		
	}

方式四

@Test
public void testFourConnection() throws Exception {

	
    //1.数据库连接的基本要素
    String url = "jdbc:mysql://localhost:3306/test";
    String user = "root";
    String password = "123456";


    //2.加载driver
    Class.forName("com.mysql.jdbc.Driver");
    //相比较于方式三,可以省略以下操作:实例化驱动,然后注册驱动
    // 实例化driver对象
    //Driver driver = (Driver)clazz.newInstance();
    注册驱动
    //DriverManager.registerDriver(driver);
    //能够这样省略是因为,在mysql的driver类中,已经帮我们做了

    
	//可以注释掉上述代码的原因,是因为在mysql的Driver类中声明有:

    static {
      try {
            DriverManager.registerDriver(new Driver());
        } catch
        (SQLException var1) {
        throw new RuntimeException("Can'tregisterdriver!");
        }
	}
    


    //4.获取链接
    Connection conn = DriverManager.getConnection(url, user,password);
    System.out.println(conn);

}

方式五(已经封装好的通用链接方法)

//最终版
//优点:
//1.实现数据和代码的分离
//2.实现解耦
//3.如果修改配置文件信息,可以避免程序 重新打包
	@Test
	public void getConnection() throws Exception {
		
		//1.读取配置文件中的基本信息
		InputStream is = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
		Properties pros = new Properties();
		pros.load(is);
		String user = pros.getProperty("user");
		String password = pros.getProperty("password");
		String url = pros.getProperty("url");
		String driverClass = pros.getProperty("driverClass");
		
		//2.加载驱动
		Class.forName(driverClass);
		
		//3.获取连接
		Connection conn = DriverManager.getConnection(url, user,password);
		System.out.println(conn);
	}
}

其中配置文件在src目录下【jdbc.properies】文件中
user=root
password=123456
url=jdbc:mysql://localhost:3306/test
driverClass=com.mysql.jdbc.Driver

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值