文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

jdbc基本使用详解

2024-04-02 19:55

关注

JDBC全称Java DataBase Connectivity / java数据库连接,是使用java连接和操作数据库的最基本驱动工具。

sun公司的javasoft部门开发

最早的JDBC 1.0 随JDK1.1发布

使用JDBC驱动的最大的好处就是可以访问不同的数据库,因为不同数据库本身提供不同的驱动以迎合JDBC驱动

流程

jdbc基本使用详解

JDBC使用流程

四大参数:

  1. driverClassName--com.mysql.jdbc.Driver(MySql数据库)

  2. url--jdbc:mysql://localhost:3306/数据库名称(MySql数据库)

  3. Uesrname

  4. Password


一、加载驱动类(注册驱动)

Class.forName("com.mysql.jdbc.Driver");

反射机制创建驱动类对象

forName静态方法:返回与给定字符串名称的类或接口相关联的类对象

com.mysql.jdbc.Driver

所有java.sql.driver的实现类都提供了static代码块,代码块中代码把自己注册到DriverManage中

(向 DriverManager 注册给定驱动程序: 新加载的驱动程序类应该调用 registerDriver 方法让 DriverManager 知道自己)

public class Driver extends NonRegisteringDriver implements java.sql.Driver {

static {

try {

java.sql.DriverManager.registerDriver(new Driver());

} catch (SQLException E) {

throw new RuntimeException("Can't register driver!");

}

}

public Driver() throws SQLException {

// Required for Class.forName().newInstance()

}

}

 

二、获取连接(通过DBUrl、UserName、PassWord)

Connection conn = DriverManager.getConnection( DB_URL, USER, PASS );

java.sql.DriverManager
用于管理一组 JDBC 驱动程序的基本服务

注意: JDBC 2.0 API中新增的DataSource接口提供了另一种连接到数据源的方法。 使用DataSource对象是连接到数据源的首选方法。

java.sql.Connection

与特定数据库的连接(会话)。在连接上下文中执行 SQL 语句并返回结果。


三、操作数据库(CURD)

 

  1. 获取Statement

Statement stmt = con.createStatement();

java.sql .Statement

用于执行静态SQL语句并返回其生成的结果的对象

在默认情况下,同一时间每个 Statement 对象在只能打开一个 ResultSet 对象

 

      2、执行execute方法(executeUpdate、executeQuery)

         executeUpdate(String sql)

          执行给定SQL 语句,该语句可能为 INSERT、UPDATE 或 DELETE 语句,或者不返回任何内容的 SQL 语句(如   SQL DDL 语句)

  方法返回值:

SQL语句执行后影响的数据行数

(1) 对于 SQL 数据操作语言 (DML) 语句,返回行计数

(2) 对于什么都不返回的 SQL 语句,返回 0

        executeQuery(String sql)

          执行给定的Query 语句语句,该语句返回单个ResultSet 对象(结果集)。

  ResultSet 
    表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。

    需解析返回的结果集

 

      3、解析ResultSet对象(一般查询操作才存在)

ResoultSet对象中的数据存储格式:二维表格

遍历结果集方法:

ResultSet 对象具有指向其当前数据行的行光标。

最初,光标被置于第一行之前。

next 方法将光标移动到下一行;因为该方法在 ResultSet 对象没有下一行时返回 false,所以可以在 while 循环中使用它来迭代结果集

jdbc基本使用详解

       next()

              将光标从当前位置向下移一行。

       两种获取列值方法:

                        1、列编号

                             getInt(int columnIndex)

                        2、列名

                             getInt(String columnLabel)



4、关闭连接(Connection、Statement、ResultSet)     

节省资源

在不使用数据库连接池情况下,connection.close()关闭时,statement和resoultset也会随之自动关闭

但是如果使用了数据库连接池,connection.close()不会关闭连接,只会归还给连接池,statement和resoultset对象就会不断持有

所以最好将ResultSet、Statement、Connection按顺序close



    


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯