JDBC编程

JDBC的全称是Java Database Connectivity,即Java数据库连接,它是一种可以执行SQL语句的Java API。通过使用JDBC,就可以使用同一种API访问不同的数据库系统。 换言之,有了JDBC API,就不必为了访问Sybase 数据库学习一组API,为访问Oracel数据库又学习一组API…..开发人员面向JDBC API编写应用程序,然后根据不同的数据库,使用不同的数据库驱动程序即可。

一. JDBC常用接口和类

JDBC API由以下常用的接口和类组成。
DriverManager :用于管理JDBC驱动的服务类。程序中使用该类的主要功能是获取Connection对象。
Connection:代表数据库连接对象,每个Connection代表一个物理连接会话。要想访问数据库,必须先获得数据库连接。
Statement: 用于执行SQL语句的工具接口。即只有获得了Statement之后才可执行SQL语句。当执行SQL查询时,返回查询到的结果集。
ResultSet :结果集对象。该对象包含访问查询结果的方法。

二. JDBC编程步骤

1) 加载数据库驱动。通常我们使用Class类的forName()静态方法来加载驱动。例如如下代码:
//加载驱动
Class.forName(driverClass);
上面代码中的driverClass就是数据库驱动类所对应的字符串。例如,加载MySQL的驱动采用如下代码:

    //加载MySQL的驱动
    Class.forName(“com.mysql.jdbc.Driver”);

而加载Oracle的驱动则采用如下代码:


    //加载Oracle的驱动
    Class.forName(“oracle.jdbc.driver.OracleDriver”);

2) 通过DriverManager获取数据库连接.DriverManager提供如下方法:

//获取数据库连接
DriverManager.getConnection(String url, String user , String pass);
当使用DriverManager获取数据库连接时,通常需要传入3个参数:数据库URL、登陆数据库的用户名和密码。
MySQL数据库的URL写法如下:

    jdbc:mysql://hostname:port/databasename

3) 通过Connection对象创建Statement对象。
createStatement() :创建基本的Statement对象

4) 使用Statement执行SQL语句。通常使用如下2个方法来执行SQL语句:
executeQuery() :只能执行查询语句,执行后返回代表查询结果的ResultSet对象。
executeUpdate() :主要用于执行操作语句(insert、update、delete)和定义语句(create、alter、drop、truncate)

5) 操作结果集。如果执行的SQL语句是查询语句,则执行结果将返回一个ResultSet对象,该对象里保存了SQL语句查询的结果。程序可以通过操作该ResultSet对象来取出查询结果。

6) 回收数据库资源,包括关闭ResultSet、Statement和Connection 等资源。

例:

public class ConnMySql{
    public static void main(String[] args){
        //1.加载驱动
        Class.forName("com.mysql.jdbc.Driver");
        try{
            //2.使用DriverManger获取数据库连接
            //返回的Connection代表了Java程序和数据库的连接
            Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/atm","root","root");
            //3.使用Connection来创建一个Statement对象
            Statement stmt = conn.createStatement();
            //4.执行SQL语句
            ResultSet rs = stmt.executeQuery("select* from account");
            //当结果集rs.next()的内容不为空,一直执行
            while(rs.next()){
            System.out.println(rs.getString(1)+"\t"+rs.getString(2));
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值