java练气期(1)----java高级(JDBC)
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)相关推荐
- java练气期(2)----java高级(File类与IO流)
什么是File类 即Java文件类以抽象的方式代表文件名和目录路径名.该类主要用于文件和目录的创建.文件的查找和文件的删除等. File类常用方法 delete()删除此抽象路径名表示的文件和目录. ...
- java练气期(3)----java高级(网络编程)
什么是java的网络编程 Socket 编程套接字使用TCP提供了两台计算机之间的通信机制. 客户端程序创建一个套接字,并尝试连接服务器的套接字. 当连接建立时,服务器会创建一个 Socket 对象. ...
- [练气期]计算机视觉之从矩阵本质修炼图像几何变换秘籍
[练气期]计算机视觉之从矩阵本质修炼图像几何变换秘籍 练气期,我们需要掌握哪些图像处理知识? 掌握OpenCV和图像处理的基础知识,并进行实践操作,具体包含: 为什么选择OpenCV,OpenCV是什 ...
- 重构修练笔记 Refactoring Xiu Lian Notes (1) - 练气期
笔记纯属虚构,如有雷同,纯属巧合 万物皆有定数,普通人入门练气期一味求快,只满足身体自身需求,对于后面更高层级没有远见,导致后面越修炼越难,极其不便和难受,从而有人直接崩盘而道陨神消.需要一种新的方法 ...
- Java修真之练气筑基篇(持续更新)
文章目录 前言 Java基础 1.1注释.标识符.关键字 注释 关键字 标识符 1.2数据类型 1.2.1强弱类型语言 强类型语言 弱类型语言 1.2.2 数据类型 类型转换 自动类型转换 强制类型转 ...
- 自学java难吗?给java初学者的一些建议
自学java到底难不难? 其实学习java说难不难,说简单也不简单.如今互联网十分发达,各种学习资料,视频,文档都可以在网上找到.可以说如今是一个全民自学的时代,你要你有决心和时间,足不出户便能学习很 ...
- 【JAVA今法修真】 第五章 练气百日,筑基三年
您好,我是南橘,万法仙门的掌门,刚刚从九州世界穿越到地球,因为时空乱流的影响导致我的法力全失,现在不得不通过这个平台向广大修真天才们借去力量.你们的每一个点赞,每一个关注都是让我回到九州世界的助力,兄 ...
- Java中如何引用另一个类里的集合_【18期】Java序列化与反序列化三连问:是什么?为什么要?如何做?...
Java序列化与反序列化是什么? Java序列化是指把Java对象转换为字节序列的过程,而Java反序列化是指把字节序列恢复为Java对象的过程: 序列化:对象序列化的最主要的用处就是在传递和保存对象 ...
- Java SE 6 新特性: Java DB 和 JDBC 4.0
http://www.ibm.com/developerworks/cn/java/j-lo-jse65/index.html 长久以来,由于大量(甚至几乎所有)的 Java 应用都依赖于数据库,如何 ...
最新文章
- Java判断文本文件编码格式以及读取
- 2021《程序员》数字科技企业研发实力榜TOP50
- PHP开发工具 zend studio
- WPF 4 Ribbon 开发 之 快捷工具栏(Quick Access Toolbar)
- Python分页组件
- 第18条:接口优于抽象类
- [Medical Image Processing] 1. Introduction
- 以太网RJ45 接线标准 线序(备忘)
- Scala连接mongodb数据库
- 独家深度 | 一文看懂 ClickHouse vs Elasticsearch:谁更胜一筹?
- python中把输出结果写到一个文件中_Python3.6笔记之将程序运行结果输出到文件的方法...
- ubuntu之安装typora
- python—itertools模块常用函数
- C# 5.0 Async函数的提示和技巧
- hdu1865 1sting
- 如何用yolov5训练自己的图片
- 数学建模常用解题方法
- 本文来自合作伙伴“阿里聚安全”.
- 需要rhce(redhat认证)证书的联系warehouse。无需自己考,直接拿证。
- Oracle中insert into select和select into的用法(异常0RA-00905:missing keyword的解决)
热门文章
- 软件测试-PR录制脚本程序的时候出现license invalid,error code=0的错误
- Java final关键字,常量的定义
- Dreamwear如何创建javascript_JavaScript还可以处理日期?你只需要这样做
- html5g与h5的区别,H5是什么?
- 浅谈如何提升数据中心制冷能效
- php防止模拟请求,php防止伪造跨站请求实现程序_PHP教程
- TF:tensorflow框架中常用函数介绍—tf.Variable()和tf.get_variable()用法及其区别
- 成功解决AttributeError: module 'numpy' has no attribute 'equal'
- DL之CycleGAN:基于TF利用CycleGAN模型对apple2orange数据集实现图像转换—训练测试过程全记录
- Python添加邮件附件并通过邮件发送测试报告