Java基础回顾系列-第九天-数据库编程

2024-09-08 15:32

本文主要是介绍Java基础回顾系列-第九天-数据库编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java基础回顾系列-第九天-数据库编程

    • 数据库简介
    • 工具包
    • java.sql API 内容
      • 与数据库建立连接
      • 执行SQL语句数据库
      • 检索和更新查询结果
      • SQL类型对应Java类型映射
      • 元数据
      • 异常
    • API方法
      • DriverManager
      • Connection
      • Statement
      • PreparedStatement
      • CallableStatement
      • ResultSet
      • java.sql.Date
      • 批处理、存储过程、事务
    • 示例

数据库简介

针对Java数据库开发的包都在java.sql包下。都是些比较基础的。
详细参见:https://docs.oracle.com/en/java/javase/11/docs/api/java.sql/java/sql/package-summary.html

工具包

  • Apache DbUtils:https://commons.apache.org/proper/commons-dbutils/
  • Hutool:https://gitee.com/loolly/hutool

java.sql API 内容

与数据库建立连接

  • DriverManager class - 与驱动程序建立连接
  • SQLPermission class - 在安全管理器(例如applet)中运行的代码尝试通过安装程序设置日志记录流时提供权限 DriverManager
  • Driverinterface - 提供基于JDBC技术注册和连接驱动程序的API(“JDBC驱动程序”); 通常只由DriverManager班级使用
  • DriverPropertyInfoclass - 提供JDBC驱动程序的属性; 一般用户不使用

执行SQL语句数据库

  • Statement - 用于发送基本的SQL语句
  • PreparedStatement- 用于发送预准备语句或基本SQL语句(派生自Statement)
  • CallableStatement- 用于调用数据库存储过程(派生自PreparedStatement)
  • Connection interface - 提供创建语句和管理连接及其属性的方法
  • Savepoint - 在事务中提供保存点

检索和更新查询结果

  • ResultSet 接口

SQL类型对应Java类型映射

  • Array 接口 - SQL的映射 ARRAY
  • Blob 接口 - SQL的映射 BLOB
  • Clob 接口 - SQL的映射 CLOB
  • Date class - SQL的映射 DATE:java.util.Date转换java.sql.Date
  • NClob 接口 - SQL的映射 NCLOB
  • Ref 接口 - SQL的映射 REF
  • RowId 接口 - SQL的映射 ROWID
  • Struct 接口 - SQL的映射 STRUCT
  • SQLXML 接口 - SQL的映射 XML
  • Time 类 - SQL的映射 TIME
  • Timestamp 类 - SQL的映射 TIMESTAMP
  • Types 类 - 为SQL类型提供常量

元数据

  • DatabaseMetaData interface - 提供有关数据库的信息
  • ResultSetMetaDatainterface - 提供有关ResultSet对象 列的信息
  • ParameterMetaDatainterface - 提供有关PreparedStatement命令 参数的信息

异常

  • SQLException - 当访问数据时出于问题而被大多数方法抛出,而出于其他原因则由某些方法抛出
  • SQLWarning - 抛出以表示警告
  • DataTruncation - 抛出表示数据可能已被截断
  • BatchUpdateException - 抛出表示批量更新中的所有命令都未成功执行

API方法

DriverManager

public static Connection getConnection​(String url, String user, String password) throws SQLException

Connection

Statement createStatement() throws SQLException
PreparedStatement prepareStatement​(String sql) throws SQLException
CallableStatement prepareCall​(String sql) throws SQLExceptionvoid setAutoCommit​(boolean autoCommit) throws SQLException
void setTransactionIsolation​(int level) throws SQLException
void commit() throws SQLException
void rollback() throws SQLException
void close() throws SQLException

Statement

int executeUpdate​(String sql) throws SQLException
ResultSet executeQuery​(String sql) throws SQLException

PreparedStatement

void setString​(int parameterIndex, String x) throws SQLException
void setInt​(int parameterIndex, int x) throws SQLException
void setTime​(int parameterIndex, Time x) throws SQLException
void setClob​(int parameterIndex, Reader reader) throws SQLExceptionResultSet executeQuery() throws SQLException
int executeUpdate() throws SQLException

CallableStatement

ResultSet

boolean next() throws SQLException
boolean last() throws SQLException
String getString​(int columnIndex) throws SQLException
String getString​(String columnLabel) throws SQLException

java.sql.Date

java.sql.Date extends java.util.Date
Java中有两个Date类,一个是java.util.Date通常情况下用它获取当前时间或构造时间,另一个是java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分。两个类型的时间可以相互转化。

java.sql包下给出三个与数据库相关的日期时间类型:

  • Date:表示日期,只有年月日,没有时分秒。会丢失时间;
  • Time:表示时间,只有时分秒,没有年月日。会丢失日期;
  • Timestamp:表示时间戳,有年月日时分秒,以及毫秒。

util.Date与sql.Date的相互转换

批处理、存储过程、事务

参见:Java-JDBC调用批处理、存储过程、事务

示例

package com.runoob.test;import java.sql.*;public class MySQLDemo {// JDBC 驱动名及数据库 URLstatic final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  static final String DB_URL = "jdbc:mysql://localhost:3306/RUNOOB";// 数据库的用户名与密码,需要根据自己的设置static final String USER = "root";static final String PASS = "123456";public static void main(String[] args) {Connection conn = null;Statement stmt = null;try{// 注册 JDBC 驱动Class.forName("com.mysql.jdbc.Driver");// 打开链接System.out.println("连接数据库...");conn = DriverManager.getConnection(DB_URL,USER,PASS);// 执行查询System.out.println(" 实例化Statement对象...");stmt = conn.createStatement();String sql;sql = "SELECT id, name, url FROM websites";ResultSet rs = stmt.executeQuery(sql);// 展开结果集数据库while(rs.next()){// 通过字段检索int id  = rs.getInt("id");String name = rs.getString("name");String url = rs.getString("url");// 输出数据System.out.print("ID: " + id);System.out.print(", 站点名称: " + name);System.out.print(", 站点 URL: " + url);System.out.print("\n");}// 完成后关闭rs.close();stmt.close();conn.close();}catch(SQLException se){// 处理 JDBC 错误se.printStackTrace();}catch(Exception e){// 处理 Class.forName 错误e.printStackTrace();}finally{// 关闭资源try{if(stmt!=null) stmt.close();}catch(SQLException se2){}// 什么都不做try{if(conn!=null) conn.close();}catch(SQLException se){se.printStackTrace();}}System.out.println("Goodbye!");}
}

这篇关于Java基础回顾系列-第九天-数据库编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1148486

相关文章

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.

Java中使用 @Builder 注解的简单示例

《Java中使用@Builder注解的简单示例》@Builder简化构建但存在复杂性,需配合其他注解,导致可变性、抽象类型处理难题,链式编程非最佳实践,适合长期对象,避免与@Data混用,改用@G... 目录一、案例二、不足之处大多数同学使用 @Builder 无非就是为了链式编程,然而 @Builder

在IntelliJ IDEA中高效运行与调试Spring Boot项目的实战步骤

《在IntelliJIDEA中高效运行与调试SpringBoot项目的实战步骤》本章详解SpringBoot项目导入IntelliJIDEA的流程,教授运行与调试技巧,包括断点设置与变量查看,奠定... 目录引言:为良驹配上好鞍一、为何选择IntelliJ IDEA?二、实战:导入并运行你的第一个项目步骤1

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

我们来说说Java LockSupport 的 park 和 unpark

《我们来说说JavaLockSupport的park和unpark》LockSupport是JDK底层线程阻塞工具,通过park/unpark实现线程阻塞与唤醒,避免死锁,与Object的w... 目录一、LockSupport1.1、LockSupport函数列表1.2、基本使用先 park 再 unpa

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor