java数据库连接

简介: JDBC详解

1. 什么是JDBC?#

JDBC全称:Java Database Connectivity,简称JDBC

2. JDBC常用的开发接口(☆)#

接口 描述
Connection 用来与数据库建立连接
Statement 用来发送SQL语句
ResultSet 执行SQL语句返回的结果集
PreparedStatement 用来发送SQL语句的,是Statement的子接口(预编译、防止SQL注入)

3. 创建JDBC的步骤(☆)#

  1. 导入数据库驱动包,加载驱动
OracleDriver od = new OracleDriver();
DriverManager.registerDriver(od);
// 参数:驱动类的完整路径
Class.forName("oracle.jdbc.driver.OracleDriver");
  1. 建立连接
Connection conn = DriverManager.getConnection(连接URL, 用户名, 密码);
("jdbc:oracle:thin:@127.0.0.1:1521:orcl,用户名, 密码")
  1. 创建可执行SQL语句的statement对象,发送SQL语句
Statement sm = conn.createStatement();
PreparedStatement ps = conn.prepareStatement(sql)
  1. 获取结果集,遍历数据
ResultSet rs = sm.executeQuery("select * from t_depart");
// 执行的SQL语句为查询语句,返回的结果是ResultSet类型
statement.executeQuery(sql);
// 执行的SQL语句为删除、修改、添加,返回的结果是int类型,代表数据库中有多少条记录被改变
statement.executeUpdate(sql);
// 执行的SQL语句为查询、删除、修改、添加,返回的结果是boolean类型,若为true,代表执行的为查询语句,否则为其他语句
statement.execute(sql);
  1. 关闭,先开的后关,后开的先关
rs.close();
sm.close();
conn.close();

4. 时间处理#

Java中有三个时间,java.util.Date时间基类,有三个子类:

时间 描述
java.sql.Date 数据库时间,精确到年月日
java.sql.Timestamp 数据库时间,精确到年月日时分秒
java.sql.Time 数据库时间,精确时分秒

5. JDBC编程思想(类与数据库对应关系)(☆)#

  • 一个类对应一张表
  • 一个属性对应一个字段
  • 一个对象对应一条记录

6. Statement与PreparedStatement区别(☆)#

PrepareStatement是Statement的子接口

  • PerparedStatement自带预编译功能,相同的SQL语句只会编译一次,提高执行效率
    Statement每次执行SQL语句都会重新编译,执行效率不高
  • PerparedStatement防止SQL注入,安全性比较高
    Statement不能防止SQL注入,安全性较低

7. 数据类型与Java类型的匹配#

数据库类型 Java类型
char String
varchar
varchar2
clob
number int
long
number(7,2) double
date java.sql.Date
timestamp java.sql.Timestamp

8. JDBC如何手动提交事务#

JDBC默认自动提交事务

  1. 把Connection对象设置成手动提交事务,代码如下:
    conn.setAutoCommit(false);
  2. 当Statement对象执行SQL语句之后,提交事务,代码如下:
int row = ps.executeUpdate();
conn.commit();
select t.*, rowid from t_newsuser t;
// 格式化表
truncate table t_newsuser;

9. 如何释放一张表的空间,提高查询效率#

select * from t_newstype;
select * from t_newstype1;
  1. 创建一张备份表
    create table t_newstype1 as select * from t_newstype;
  2. 清空原表
    truncate table t_newstype;
  3. 还原数据
insert into t_newstype select * from t_newstype1;
commit;
  1. 删除备份表
    drop table t_newtype1;

10. executeUpdate与executeQuery的区别#

  • executeUpdate:执行的语句是DDL、DML,DDL几乎不用,返回值为:影响行数(int)
  • drop:删除表结构,并且删除数据,释放表空间
  • truncate:保留表结构,清除数据,释放表空间
  • delete:保留表结构,删除指定数据,提交事务,不一定释放空间
  • executeQuery:执行的语句是DQL,select查询语句,返回值为:结果集(ResultSet)

10. JDBC常见异常#

常见异常 可能引起原因
标识符无效 字段名单词写错
索引中丢失IN或OUT 字段名与?个数不匹配
无效的列索引 参数多余?
ORA-00911:无效字符 多个无效的字符,例如:分号
列在此处不允许 数据类型不匹配
目录
相关文章
|
5天前
|
监控 Java 数据库连接
Java中如何实现数据库连接池优化?
Java中如何实现数据库连接池优化?
|
6天前
|
监控 Java 数据库连接
Java开发者必读:连接池技术如何提升数据库连接效率
【6月更文挑战第24天】Java开发中,面对高并发的数据库访问,连接池技术成为性能优化的关键。它预先创建连接池,减少频繁的连接创建/关闭,提升响应速度,节省资源,并增强系统稳定性。例如,HikariCP连接池通过配置实现DB连接管理,简化代码并提升应用性能。
|
6天前
|
Java 数据库连接 数据库
深入探索:Java连接池在数据库性能优化中的角色
【6月更文挑战第24天】Java应用中,数据库连接池如HikariCP提升性能,减少资源消耗。连接池预创建并管理连接,避免频繁创建/关闭。工作流程:申请连接→池中取或新建→使用后归还给池。示例展示了如何配置及使用HikariCP连接池,强调了其在高并发环境中的重要性。选择合适连接池并优化配置对系统性能至关重要。
|
5天前
|
SQL Java 关系型数据库
Java中的JDBC编程:从数据库连接到高级查询
Java中的JDBC编程:从数据库连接到高级查询
|
5天前
|
存储 安全 Java
如何在Java中实现数据库连接池?
如何在Java中实现数据库连接池?
|
5天前
|
SQL Java 数据库连接
Java中如何优化数据库查询性能?
Java中如何优化数据库查询性能?
|
5天前
|
SQL Java 数据库连接
如何在Java中实现数据库事务?
如何在Java中实现数据库事务?
|
5天前
|
缓存 Java 数据库连接
解析Hibernate与JPA:Java对象的数据库化之旅
【6月更文挑战第25天】在Java企业开发中,Hibernate和JPA提供优雅的数据持久化方案。Hibernate是JPA规范的强大ORM实现,简化对象与数据库映射。配置环境后,通过@Entity注解定义实体类映射表,如`User`类映射"users"表。利用JPA的EntityManager执行查询和更新,如JPQL查询及对象更新。事务管理和性能优化是关键,确保数据完整性和应用性能。本文揭示了Hibernate与JPA的最佳实践,助开发者从容应对数据持久化。
|
5天前
|
Java 数据库连接 API
数据库与Java的无缝对接:Hibernate与JPA的集成与应用
【6月更文挑战第25天】Java企业级应用中,Hibernate和JPA是ORM主流框架。JPA是标准API,定义对象-关系映射规范,强调标准化和可移植性。Hibernate是JPA的具体实现,扩展了更多功能,如强大的查询语言和缓存机制。两者集成允许开发者利用Hibernate性能,通过JPA注解保持代码规范。示例展示了如何使用JPA注解定义实体和Hibernate执行查询,实现数据库操作。这种方式提升了开发效率和应用质量。
|
5天前
|
存储 Java 数据库连接
深入探索Hibernate与JPA:Java对象与数据库表的桥梁
【6月更文挑战第25天】Java ORM如Hibernate和JPA简化了数据库交互。在电商系统案例中,JPA注解如`@Entity`、`@Table`、`@Id`定义了对象-表映射。Hibernate利用这些定义实现持久化,如`Session.save()`保存用户对象至数据库,降低了复杂性并提升了开发效率。