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中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为