1.什么是JDBC?

JDBC: Java Database Connectivity  为多种关系型数据库提供统一访问。即通过Java代码访问和操作数据库

JDBC连接数据库的步骤

//JDBC的工具类代码,为持久层服务
package com.lkw.util;import java.sql.*;public class DBHelper {/*** <pre>* JDBC驱动程序,默认为MySQL* MySQL: <b>com.mysql.jdbc.Driver</b>* MSSQLServer: <b>com.microsoft.sqlserver.jdbc.SQLServerDriver</b>* </pre>*/private static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";/*** <pre>* JDBC数据库URL,默认为MySQL* MySQL:<b>jdbc:mysql://localhost:3306/数据库名</b>* MSSQLServer:<b>jdbc:sqlserver://localhost:1433;DatabaseName=数据库名</b>* </pre>*/private static final String JDBC_URL = "jdbc:mysql://localhost:3306/exam";/*** JDBC登录数据库服务器用户名和密码*/private static final String JDBC_USER = "root";private static final String JDBC_PASSWORD = "root";private static DBHelper db = null;private  static Connection conn = null;private  static PreparedStatement st = null;static {try {//加载驱动程序Class.forName(JDBC_DRIVER);} catch (ClassNotFoundException e) {e.printStackTrace();}}private  DBHelper() throws SQLException {//获取数据库连接conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD);}//获取DBHelper对象public static  DBHelper getInstance() throws SQLException {if(db == null || conn.isClosed()) {db = new DBHelper();}return db;}//查询public ResultSet executeQuery(String sql, Object...args) throws SQLException {st  = conn.prepareStatement(sql);//预处理if(args != null && args.length > 0) {for(int i = 0; i < args.length; ++i){st.setObject(i + 1, args[i]);}}return st.executeQuery();}
//增删改public int executeUpdate(String sql, Object...args) throws SQLException {st = conn.prepareStatement(sql);if(args != null && args.length > 0) {for(int i = 0; i < args.length; ++i) {st.setObject(i + 1, args[i]);}}return st.executeUpdate();}/*关闭对象*/public static void close() {if(st != null ) {try {st.close();} catch (SQLException e) {e.printStackTrace();}finally {if(conn != null){try {conn.close();} catch (SQLException e) {e.printStackTrace();}finally{st = null;conn = null;db = null;}}}}}}

2. 简述JDBC的Resulset,与Connection类

ResultSet是结果集,用来存放执行sql后返回的执行结果,对应于数据库中的数据表

Connrction:与数据库连接的对象

3.JDBC中,PreparedStatement相较于Statement有什么优点?

1)PreparedStatement可以使用预编译的sql,而Statment只能使用静态的sql

2)PreparedStatement可以使用sql缓存区,效率比Statment高

3)PreparedStatement可以有效防止sql注入,而Statment不能防止sql注入。

4.JDBC中如何进行事务处理?

一个事务是由一条或多条对数据库操作的SQL语句所组成的一个不可分割的工作单元,只有当事务中的所有操作都正常执行了,整个事务才会被提交给数据库。在JDBC中,一般是通过commit()方法或rollback()方法来结束事务的操作。其中commit()方法表示完成对事务的提交,rollback()方法表示完成事务回滚,多用于在处理事务的过程中出现了异常的情况,这两种方法都位于java.sql.Connection类中。一般而言,事务默认操作是自动提交,即操作成功后,系统将自动调用commit()方法,否则将调用rollback()方法。

当然,在JDBC中,也可以通过调用setAutoCommit(false)方法来禁止自动提交,然后就可以把多个数据库操作的表达式作为一个事务,在操作完成后调用commit()方法实现整体提交,如果其中一个表达式操作失败,就会抛出异常而不会调用commit()方法。在这种情况下,就可以在异常捕获的代码块中调用rollback()进行事务回滚。通过此种方法可以保持对数据库的多次操作后,数据仍然保持一致性。

JDBC事务处理的方法

try{con.setAutoCommit(false);//开启事务......con.commit();//try的最后提交事务
} catch() {con.rollback();//回滚事务
}

5.在进行数据库编程时,连接池有什么作用?

实际开发中“获得连接”或“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况我们采用连接池技术,来共享连接Connection。

用池来管理Connection,这样可以重复使用Connection。有了池,所以我们就不用自己来创建Connection,而是通过池来获取Connection对象。当使用完Connection后,调用Connection的close()方法也不会真的关闭Connection,而是把Connection“归还”给池。池就可以再利用这个Connection对象了。

常见的连接池有C3P0、DBCP。

C3P0开源免费的连接池!目前使用它的开源项目有:Spring、Hibernate等。使用第三方工具需要导入jar包,c3p0使用时还需要添加配置文件c3p0-config.xml。

DBCP也是一个开源的连接池,是Apache Common成员之一,在企业开发中也比较常见,tomcat内置的连接池。

java练气期(1)----java高级(JDBC)相关推荐

  1. java练气期(2)----java高级(File类与IO流)

    什么是File类 即Java文件类以抽象的方式代表文件名和目录路径名.该类主要用于文件和目录的创建.文件的查找和文件的删除等. File类常用方法 delete()删除此抽象路径名表示的文件和目录. ...

  2. java练气期(3)----java高级(网络编程)

    什么是java的网络编程 Socket 编程套接字使用TCP提供了两台计算机之间的通信机制. 客户端程序创建一个套接字,并尝试连接服务器的套接字. 当连接建立时,服务器会创建一个 Socket 对象. ...

  3. [练气期]计算机视觉之从矩阵本质修炼图像几何变换秘籍

    [练气期]计算机视觉之从矩阵本质修炼图像几何变换秘籍 练气期,我们需要掌握哪些图像处理知识? 掌握OpenCV和图像处理的基础知识,并进行实践操作,具体包含: 为什么选择OpenCV,OpenCV是什 ...

  4. 重构修练笔记 Refactoring Xiu Lian Notes (1) - 练气期

    笔记纯属虚构,如有雷同,纯属巧合 万物皆有定数,普通人入门练气期一味求快,只满足身体自身需求,对于后面更高层级没有远见,导致后面越修炼越难,极其不便和难受,从而有人直接崩盘而道陨神消.需要一种新的方法 ...

  5. Java修真之练气筑基篇(持续更新)

    文章目录 前言 Java基础 1.1注释.标识符.关键字 注释 关键字 标识符 1.2数据类型 1.2.1强弱类型语言 强类型语言 弱类型语言 1.2.2 数据类型 类型转换 自动类型转换 强制类型转 ...

  6. 自学java难吗?给java初学者的一些建议

    自学java到底难不难? 其实学习java说难不难,说简单也不简单.如今互联网十分发达,各种学习资料,视频,文档都可以在网上找到.可以说如今是一个全民自学的时代,你要你有决心和时间,足不出户便能学习很 ...

  7. 【JAVA今法修真】 第五章 练气百日,筑基三年

    您好,我是南橘,万法仙门的掌门,刚刚从九州世界穿越到地球,因为时空乱流的影响导致我的法力全失,现在不得不通过这个平台向广大修真天才们借去力量.你们的每一个点赞,每一个关注都是让我回到九州世界的助力,兄 ...

  8. Java中如何引用另一个类里的集合_【18期】Java序列化与反序列化三连问:是什么?为什么要?如何做?...

    Java序列化与反序列化是什么? Java序列化是指把Java对象转换为字节序列的过程,而Java反序列化是指把字节序列恢复为Java对象的过程: 序列化:对象序列化的最主要的用处就是在传递和保存对象 ...

  9. Java SE 6 新特性: Java DB 和 JDBC 4.0

    http://www.ibm.com/developerworks/cn/java/j-lo-jse65/index.html 长久以来,由于大量(甚至几乎所有)的 Java 应用都依赖于数据库,如何 ...

最新文章

  1. Java判断文本文件编码格式以及读取
  2. 2021《程序员》数字科技企业研发实力榜TOP50
  3. PHP开发工具 zend studio
  4. WPF 4 Ribbon 开发 之 快捷工具栏(Quick Access Toolbar)
  5. Python分页组件
  6. 第18条:接口优于抽象类
  7. [Medical Image Processing] 1. Introduction
  8. 以太网RJ45 接线标准 线序(备忘)
  9. Scala连接mongodb数据库
  10. 独家深度 | 一文看懂 ClickHouse vs Elasticsearch:谁更胜一筹?
  11. python中把输出结果写到一个文件中_Python3.6笔记之将程序运行结果输出到文件的方法...
  12. ubuntu之安装typora
  13. python—itertools模块常用函数
  14. C# 5.0 Async函数的提示和技巧
  15. hdu1865 1sting
  16. 如何用yolov5训练自己的图片
  17. 数学建模常用解题方法
  18. 本文来自合作伙伴“阿里聚安全”.
  19. 需要rhce(redhat认证)证书的联系warehouse。无需自己考,直接拿证。
  20. Oracle中insert into select和select into的用法(异常0RA-00905:missing keyword的解决)

热门文章

  1. 软件测试-PR录制脚本程序的时候出现license invalid,error code=0的错误
  2. Java final关键字,常量的定义
  3. Dreamwear如何创建javascript_JavaScript还可以处理日期?你只需要这样做
  4. html5g与h5的区别,H5是什么?
  5. 浅谈如何提升数据中心制冷能效
  6. php防止模拟请求,php防止伪造跨站请求实现程序_PHP教程
  7. TF:tensorflow框架中常用函数介绍—tf.Variable()和tf.get_variable()用法及其区别
  8. 成功解决AttributeError: module 'numpy' has no attribute 'equal'
  9. DL之CycleGAN:基于TF利用CycleGAN模型对apple2orange数据集实现图像转换—训练测试过程全记录
  10. Python添加邮件附件并通过邮件发送测试报告