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

相关文章

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3