JDBC简述Java数据库连接(Java Database connectivity)简称为JDBC,是Java程序与数据库系统通信的标准API,它包含一组用Java语言编写的类和接口。
通过JDBC可以方便的向各种关系数据库发送SQL语句。也就是说,开发人员不需要为访问不同的数据库而编写不同的应用程序,而只需使用JDBC编写一个通用程序就可以向不同的数据库发送SQL调用。
由于Java的平台无关性,使用Java编写的应用程序可以运行在任何支持Java语言的平台上,而无须针对不同平台编写不同的应用程序。将Java和JDBC结合起来操作数据库可以真正实现“一次编写,处处运行”。
使用JDBC连接MySQL数据库步骤
假设MySQL中有book表,有bookid和name两个属性,类型都为String。
① 调用Class.forName()方法加载相应的数据库驱动程序1Class.forName("com.mysql.jdbc.Driver");
② 定义要连接数据库的地址URL,格式为:jdbc::。1String mysqlURL = "jdbc:mysql://host:port/dbname";
③ 使用驱动程序类建立与数据库的连接。调用DriverManager对象的getConnection()方法,获得一个Connection对象,它表示一个打开的连接。1Connection conn = DriverManager.getConnection(URL,"数据库用户名","密码");
④ 创建语句对象1
2/* Statement用于传递简单的不带参数的SQL语句给数据库管理系统执行 */
Statement stmt = conn.createStatement();1
2/* PreparedStatement用于传送带有一个或多个参数的SQL语句 */
PreparedStatement psm = conn.prepareStatement("INSERT INTO book(bookid, name)VALUES(?,?)");1
2/* CallableStatement对象用于调用存储过程 validate是存储过程名*/
CallableStatement csm = conn.prepareCall("{call validate(?,?)}");
⑤ 执行语句
Statement接口提供了3个方法执行SQL语句,分别是executeQuery、executeUpdate和execute。executeQuery:用于执行SQL查询语句,并返回单个结果集,保存在ResultSet对象中。1
2String sql = "SELECT * FROM book";
ResultSel rs = stmt.executeQuery(sql);executeUpdate:可用于执行SQL DML(数据库操纵语句)语句,即INSERT、UPDATE和DELETE语句。此时返回受影响的行数,返回值为一个整数。 也可用于执行SQL DDL(数据库定义语句)语句,如CREATE TABLE、DROP TABLE等,此时返回值为0.
execute:既可以执行查询语句,也可以执行更新语句,常用于动态处理类型未知的SQL语句。
⑥ 对返回的结果集ResultSet对象进行处理
ResultSet对象包含了SQL语句的执行结果,它使用一组get方法实现对结果行中每列数据的访问。使用next方法移动到下一行,使其成为当前行。1
2
3
4
5
6
7
8String sql = "SELECT * FROM book";
ResultSel rs = stmt.executeQuery(sql);
/* 对结果集进行迭代 显示所有记录的前两列 */
while(re.next()){
bookid = rs.getString(1);
name = rs.getString(2);
System.out.println(bookid + "," + name);
}
⑦ 关闭连接。 操作完成后要关闭所有JDBC对象,以释放资源。包括:关闭结果集、关闭语句对象和连接对象。1
2
3rs.close();
stmt.close();
conn.close();