- 把数据保存到可掉电式存储设备中以供之后使用。大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以”固化”,而持久化的实现过程大多通过各种关系数据库来完成。
- 持久化的主要应用是将内存中的数据存储在关系型数据库中,当然也可以存储在磁盘文件、XML数据文件中。
-
JDBC直接访问数据库
-
JDO (Java Data Object )技术
-
第三方O/R工具,如Hibernate, Mybatis等
JDBC是java访问数据库的基石,JDO、Hibernate、MyBatis等只是更好的封装了JDBC
- JDBC( Java Database Connectivity)是一个独立于特定数据库管理系统、通用的SQL数据库存取和操作的公共接口(一组API),定义了用来访问数据库的标准Java类库,(java.sql,javax.sql)使用这些类库可以以一种标准的方法、方便地访问数据库资源。
- JDBC为访问不同的数据库提供了一种统一的途径,为开发者屏蔽了一些细节问题。
- JDBC的目标是使Java程序员使用JDBC可以连接任何提供了JDBC驱动程序的数据库系统,这样就使得程序员无需 对特定的数据库系统的特点有过多的了解,从而大大简化和加快了开发过程。
-
面向应用的API:Java API,抽象接口,供应用程序开发人员使用(连接数据库,执行SQL语句,获得结果)
-
面向数据库的API:Java Driver API,供开发商开发数据库驱动程序用
// 导包
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



