简述使jdbc连接mysql数据库,使用JDBC连接MySQL

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();

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值