java使用JDBC操作数据库的包含以下7个主要步骤:

1、加载JDBC驱动程序

在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),这通过java.lang.Class类的静态方法forName(String  className)实现。例如:

[html] view plaincopy
  1. try{
  2. //加载MySql的驱动类
  3. Class.forName("com.mysql.jdbc.Driver") ;
  4. }catch(ClassNotFoundException e){
  5. System.out.println("找不到驱动程序类 ,加载驱动失败!");
  6. e.printStackTrace() ;
  7. }

成功加载后,会将Driver类的实例注册到DriverManager类中。

2、提供JDBC连接的URL

连接URL定义了连接数据库时的协议、子协议、数据源标识。   
   书写形式:协议:子协议:数据源标识   
          协议:在JDBC中总是以jdbc开始   
          子协议:是桥连接的驱动程序或是数据库管理系统名称。   
          数据源标识:标记找到数据库来源的地址与连接端口。   
    例如:(MySql的连接URL)jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=gbk ;   
   useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为gb2312或GBK,本参数必须设置为true 。characterEncoding=gbk:字符编码方式。

3、创建数据库的连接

要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,该对象就代表一个数据库的连接使用DriverManager的getConnectin(String url , String username ,  String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和 密码来获得。   
     例如:

[html] view plaincopy
  1. //连接MySql数据库,用户名和密码都是root
  2. String url = "jdbc:mysql://localhost:3306/test" ;
  3. String username = "root" ;
  4. String password = "root" ;
  5. try{
  6. Connection con =
  7. DriverManager.getConnection(url , username , password ) ;
  8. }catch(SQLException se){
  9. System.out.println("数据库连接失败!");
  10. se.printStackTrace() ;
  11. }

4、创建一个Statement

要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3 种类型:   
      1、执行静态SQL语句。通常通过Statement实例实现。   
      2、执行动态SQL语句。通常通过PreparedStatement实例实现。   
      3、执行数据库存储过程。通常通过CallableStatement实例实现。   
    具体的实现方式:

[html] view plaincopy
  1. Statement stmt = con.createStatement() ;
  2. PreparedStatement pstmt = con.prepareStatement(sql) ;
  3. CallableStatement cstmt =   con.prepareCall("{CALL demoSp(? , ?)}") ;

5、执行SQL语句

Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate 和execute   
    1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句,返回一个结果集(ResultSet)对象。   
     2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等   
     3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的语句。   
   具体实现的代码:

[html] view plaincopy
  1. ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;
  2. int rows = stmt.executeUpdate("INSERT INTO ...") ;
  3. boolean flag = stmt.execute(String sql) ;

6、处理结果

两种情况:   
         1、执行更新返回的是本次操作影响到的记录数。   
         2、执行查询返回的结果是一个ResultSet对象。   
         ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些行中数据的访问。使用结果集(ResultSet)对象的访问方法获取数据,例如:

[html] view plaincopy
  1. while(rs.next()){
  2. String name = rs.getString("name") ;
  3. String password = rs.getString(1) ; // 此方法比较高效
  4. }

(列是从左到右编号的,并且从列1开始)

7、关闭JDBC对象

操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声明顺序相反:   
     1、关闭记录集   
     2、关闭声明   
     3、关闭连接对象   
     例如:

[html] view plaincopy
  1. if(rs != null){   // 关闭记录集
  2. try{
  3. rs.close() ;
  4. }catch(SQLException e){
  5. e.printStackTrace() ;
  6. }
  7. }
  8. if(stmt != null){   // 关闭声明
  9. try{
  10. stmt.close() ;
  11. }catch(SQLException e){
  12. e.printStackTrace() ;
  13. }
  14. }
  15. if(conn != null){  // 关闭连接对象
  16. try{
  17. conn.close() ;
  18. }catch(SQLException e){
  19. e.printStackTrace() ;
  20. }
  21. }

java完整JDBC操作数据库相关推荐

  1. java和jdbc操作数据库MySQL

    大家初学java连接数据库一定遇到不少问题吧,我遇到这些问题也很头痛,所以我我把我初学jdbc连接数据库写的代码直接分享给大家.最后有完整代码可以直接复制运行 建表语句 CREATE TABLE `c ...

  2. jdba访问mysql_Java中JDBC操作数据库的步骤

    Java中JDBC操作数据库的步骤,今天给喜欢Java开发或者是想要参加Java培训学习的小伙伴们分享一些Java技能干货,那就是Java阐述jdba操作数据库的步骤,废话不多说了,随小编一起来看一下 ...

  3. Java数据库开发与应用之MySQL数据库、JDBC操作数据库、C3P0数据库连接池,Java反射等

    MySQL数据库,JDBC接口,MyBatis框架等,掌握的数据的存放和管理. Java数据库开发基础,介绍MySQL数据库.JDBC操作数据库.C3P0数据库连接池,Java反射等内容,进行油画商城 ...

  4. Java使用Jdbc操作MySql数据库(一)

    这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...

  5. java监听数据库操作_第十六篇——JDBC操作数据库之监听器

    JavaWeb应用中,很多的地方都和session有关.因此session相关的事件监听器,在日常工作中非常有用. 有时候我们需要统计当前在线的人数和访问人数总数,此时就可以使用监听器技术来很简单的实 ...

  6. Java系列技术之JDBC操作数据库-钟洪发-专题视频课程

    Java系列技术之JDBC操作数据库-22人已学习 课程介绍         JDBC连接数据库是Java系列技术中数据库知识的核心技术,是学习后续课程JavaWeb入门前需要掌握的基础! 这门课的前 ...

  7. Java笔记(第七篇 JDBC操作数据库)

    JDBC是连接数据库和java程序的桥梁,通过JDBC API可以方便地实现对各种主流数据库的操作.学习java语言,必须学习JDBC技术,因为JDBC技术实在java语言中被广泛使用的一种操作数据库 ...

  8. JavaWeb:用JDBC操作数据库

    JDBC系列阅读 JavaWeb:用JDBC操作数据库 JavaWeb:JDBC之事务 JavaWeb:JDBC之数据库连接池 使用JDBC实现水果超市管理系统 1. 什么是JDBC JDBC的全称是 ...

  9. JDBC操作数据库实例

    返回目录:<学生信息管理系统(Java+JSP)> 这里以JDBC操作MySQL数据库为例. 假设有一个名为test的数据库,里面有一张学生表,表名称为student,表结构如下: stu ...

最新文章

  1. 聊聊 #pragma 和 // MARK:
  2. python连接access 参数太少_带参数的PypyODBC:[ODBC Microsoft Access Driver]参数太少。预期4...
  3. 数据值、列类型和数据字段属性
  4. 二位数组的随机生成,遍历,求和,反转。和两个变量的^反转 源码
  5. 百钱买白鸡与啤酒饮料
  6. 线程----Monitor(互斥锁)类设置超时值
  7. hadoop2.2单节点集群的搭建
  8. 设计模式学习笔记(1)——单例模式
  9. oralce insert 时,出现的两个错误,以及解决方法
  10. 34.卷1(套接字联网API)---常用函数
  11. 机器学习系统设计(一)--入门之环境搭建
  12. CMU 15-213 Introduction to Computer Systems学习笔记(8) Machine-Level Programming-Advanced
  13. kali扫描内网ip_kali linux 如何查找局域网ip
  14. 基于MATLAB的图像复原
  15. nas服务器搭建网站,小白都能看懂的NAS服务器搭建教程
  16. GRUB4DOS(九)常用设备类型及map命令用法示例
  17. 浙江大学计算机学院 翁恺,“中文MOOC第一人”浙江大学教师翁恺获得百万大奖...
  18. BulletProof vs snark vs stark性能对比
  19. 请简述一下”==”和”equals”的区别
  20. UML画图总结以及浅谈UNL九种图

热门文章

  1. 前端结构解析系列之二:凯旋门结构
  2. 异常为当IDENTITY_INSERT设置为OFF时 的解决
  3. 年轻人“躺平”的生活方式,引起不少争议
  4. Android报错:FAILED:_nl_intern_locale_data: ?? ‘cnt < (sizeof (_nl_value_type_LC_TIME)
  5. Android USB(type-c)耳机(十)
  6. Mac下载配置aria2和baidudl
  7. h.264保存flv文件
  8. java不同项目加token访问_利用JWT实现前后端分离的Token验证
  9. Python灰度图像彩色化
  10. Java 核心 API 必须掌握的程度