首页 > 编程语言 >JDBC编程

JDBC编程

时间:2023-06-18 16:44:06浏览次数:35  
标签:语句 事务 JDBC 编程 try connection preparedStatement sql

前置知识

  1. Java 中 Properties 类是用于读取配置文件(.properties 、.cfg)中的配置信息。通常会将变动不大的配置信息存储在以 .properties 结尾的配置文件中,可以通过 java.util.Properties 类读取配置文件,将配置信息注入到配置类中
    1. 如 properties 文件内容的格式是 键=值 形式,键不能够重复 java.driver=com.mysql.jdbc.Driver
  2. 什么是事务:事务是逻辑上的一组操作组合,要么都执行成功,要么执行失败回滚
    1. 事务能否生效的关键是 数据库引擎 是否支持事务。比如MySQL数据库默认使用的存储引擎是InnoDB,它支持事务,但是MyISAM存储引擎不支持事务
  3. 事务四大特性(ACID)
    1. 原子性(Atomicity):事务是一个不可分割的工作单位,事务中的操作要么全部成功,要么全部失败
    2. 一致性(Consistency):事务必须使数据库从一个一致性状态变为另一个一致性状态。即事务按照预期效果生效,数据状态也是预期的状态
    3. 隔离性(Isolation):在多个用户并发访问数据库时,数据库为每一个用户开启的事物,不能别其他事务操作数据所干扰,多个并发事务之间要相互隔离
    4. 持久性(Durability):事务一旦被提交,对数据库的数据更改是永久性的,即使数据库故障也不会被影响到

JDBC简介

JDBC是一套统一的、基于Java语言的关系数据库编程接口规范,允许把SQL语句作为参数通过JDBC接口发送给数据库,数据库接受到SQL后进行语法分析、验证,然后执行、响应。在JDBC接口规范的基础上,不同的关系型数据库厂商提供了访问自己数据库的具体实现,这些具体的实现称为JDBC驱动


JDBC相关接口说明

DriverManager

驱动管理器,提供驱动注册方法,并管理着一个已经注册到DriverManager中的驱动列表

Driver

Driver接口由数据库厂家提供,作为开发人员,只需要使用Driver接口就可以了。在编程中要连接数据库,必须先装载特定厂商的数据库驱动程序,如:

  • 装载MySQL驱动:Class.forName("com.mysql.jdbc.Driver");

Connection

它表示程序与数据库服务器之间的单个连接,通过它可以发送一系列SQL语句到数据库服务器,并且可以控制这些SQL语句的提交和终止

  • 连接MySQL数据库:Connection connection = DriverManager.getConnection("jdbc:mysql://host:port/database", "user", "password");

常用Connection方法

  • createStatement():创建Statement对象,执行静态SQL语句
  • prepareStatement(sql) :预处理SQL语句,返回PrepareStatement对象
  • prepareCall(sql):预处理存储过程的调用,返回CallableStatement对象
  • setAutoCommit(boolean autoCommit):设置事务是否自动提交
  • commit() :提交事务
  • rollback() :回滚事务
  • close():关闭连接

Statement

用于执行静态SQL语句并返回它所生成结果的对象

三种Statement类:

  • Statement:由方法connection.createStatement()创建,用于发送简单的SQL语句(不带参数)
  • PreparedStatement :由方法connection.prepareStatement(sql)创建,用于发送含有一个或多个参数的SQL语句。PreparedStatement对象比Statement对象的效率更高,并且可以防止SQL注入
  • CallableStatement:由方法connection.prepareCall()创建,用于调用存储过程

常用Statement方法:

  • execute(String sql):运行sql语句,返回是否有结果集
  • executeQuery(String sql):运行select语句,返回ResultSet结果集
  • executeUpdate(String sql):运行insert/update/delete操作,返回更新的行数
  • addBatch(String sql) :把多条sql语句放到一个批处理中
  • executeBatch():向数据库发送一批sql语句执行

ResultSet

查询结果集处理接口,Statement及其子类执行executeQuery方法后返回该类型对象

常用方法:

  • next():使游标从结果集的当前位置向前移动一行(注意:游标初始位置是在第一行之前,所以第一次执行next方法后游标指向第一行)
  • getXXX(columnIndex):获取XXX类型的第columnIndex列的值(columnIndex指select子句中字段的索引,从1开始)
  • getXXX(columnLabel):获取XXX类型的字段名(或别名)为columnLabel的字段值
  • getObject(columnIndex | columnLabel):根据查询结果中列的索引位置或字段名获取字段值
  • close():释放资源

 JDBC入门使用

具体步骤:

  1. 加载JDBC驱动程序
  2. 建立数据库连接Connection
  3. 创建执行SQL的语句Statement
  4. 处理执行结果ResultSet
  5. 释放资源 

导入依赖

<!--mysql驱动-->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.28</version>
</dependency>

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>RELEASE</version>
    <scope>compile</scope>
</dependency>

创建DB的配置文件

jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/jdbc
jdbc.username=root
jdbc.password=123456

创建JDBC工具类 

用于加载JDBC驱动程序,提供获取Connection对象和释放资源方法

import java.io.IOException;
import java.sql.*;
import java.util.Objects;
import java.util.Properties;

/**
 * @describe 读取数据库配置文件,获取连接对象
 */
public class JdbcUtils {

    public static Properties properties = new Properties();

    static {
        try {
            //加载properties配置文件
            properties.load(ClassLoader.getSystemResourceAsStream("db.properties"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 获取connection对象
     */
    public static Connection getConnection() {
        try {
            //注册驱动
            Class.forName(properties.getProperty("jdbc.driver"));
            //建立连接
            return DriverManager
                    .getConnection(properties.getProperty("jdbc.url"), properties.getProperty("jdbc.username"), properties.getProperty("jdbc.password"));
        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 释放资源
     */
    public static void release(ResultSet resultSet, Statement statement, Connection connection) {

        try {
            if (Objects.nonNull(resultSet)) {
                resultSet.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }

        try {
            if (Objects.nonNull(statement)) {
                statement.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }

        try {
            if (Objects.nonNull(connection)) {
                connection.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

JDBC的使用 

建表

CREATE TABLE users (
    id int(11) NOT NULL AUTO_INCREMENT,
    name varchar(30) DEFAULT NULL,
    password varchar(32) DEFAULT NULL,
    email varchar(20) DEFAULT NULL,
    birthday date DEFAULT NULL,
    introduction longblob,
    create_at timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
    PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

实体类 

@Data
@AllArgsConstructor
public class User implements Serializable {

    private Long id;
    private String name;
    private String password;
    private String email;
    private Date birthday;
    private Blob introduction;
    private LocalDateTime createAt;

    @Tolerate
    public User() {

    }
}

JDBC的CRUD

import com.wen.pojo.User;
import com.wen.utils.JdbcUtils;

import java.io.*;
import java.sql.*;
import java.time.LocalDateTime;
import java.util.Objects;

public class UserTest {

    public static void main(String[] args) {
        query();
    }


    public static void insert() {
        Connection connection = JdbcUtils.getConnection();
        PreparedStatement preparedStatement = null;
        try {
            if (Objects.nonNull(connection)) {
                //手动提交事务
                connection.setAutoCommit(false);
                //创建预编译sql语句
                String insertSql = "insert into users(name,password,email,birthday,introduction,create_at) values(?,?,?,?,?,?)";
                preparedStatement = connection.prepareStatement(insertSql);
                preparedStatement.setString(1,"mysql");
                preparedStatement.setString(2,"123456");
                preparedStatement.setString(3,"[email protected]");
                preparedStatement.setDate(4, new Date(System.currentTimeMillis()));
                preparedStatement.setClob(5, new BufferedReader(new InputStreamReader(new ByteArrayInputStream("hello world".getBytes()))));
                preparedStatement.setTimestamp(6, Timestamp.valueOf(LocalDateTime.now()));
                //执行sql语句
                preparedStatement.execute();
                //提交事务
                connection.commit();
            }
        } catch (SQLException e) {
            e.printStackTrace();
            try {
                //异常回滚
                connection.rollback();
            } catch (SQLException sqlException) {
                sqlException.printStackTrace();
            }
        } finally {
            //关闭连接
            JdbcUtils.release(null,preparedStatement,connection);
        }
    }

    public static void update() {
        Connection connection = JdbcUtils.getConnection();
        PreparedStatement preparedStatement = null;
        try {
            if (Objects.nonNull(connection)) {
                //手动提交事务
                connection.setAutoCommit(false);
                //创建预编译sql语句
                String updateSql = "update users set name = ?,password = ?,create_at = ? where id = ?";
                preparedStatement = connection.prepareStatement(updateSql);
                preparedStatement.setString(1,"mysql");
                preparedStatement.setString(2,"456789");
                preparedStatement.setTimestamp(3,Timestamp.valueOf(LocalDateTime.now()));
                preparedStatement.setLong(4,1);
                //执行sql语句
                preparedStatement.executeUpdate();
                //提交事务
                connection.commit();
            }
        } catch (SQLException e) {
            e.printStackTrace();
            try {
                //异常回滚
                connection.rollback();
            } catch (SQLException sqlException) {
                sqlException.printStackTrace();
            }
        } finally {
            JdbcUtils.release(null,preparedStatement,connection);
        }
    }

    public static void delete() {
        Connection connection = JdbcUtils.getConnection();
        PreparedStatement preparedStatement = null;
        try {
            if (Objects.nonNull(connection)) {
                //手动提交事务
                connection.setAutoCommit(false);
                //创建预编译sql语句
                String deleteSql = "delete from users where id = ?";
                preparedStatement = connection.prepareStatement(deleteSql);
                preparedStatement.setLong(1,1);
                //执行sql语句
                preparedStatement.executeUpdate();
                //提交事务
                connection.commit();
            }
        } catch (SQLException e) {
            e.printStackTrace();
            try {
                //异常回滚
                connection.rollback();
            } catch (SQLException sqlException) {
                sqlException.printStackTrace();
            }
        } finally {
            //关闭连接
            JdbcUtils.release(null,preparedStatement,connection);
        }
    }

    public static void query(){
        Connection connection = JdbcUtils.getConnection();
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        try {
            if (Objects.nonNull(connection)) {
                //手动提交事务
                connection.setAutoCommit(false);
                //创建预编译sql语句
                String deleteSql = "select * from users order by birthday desc";
                preparedStatement = connection.prepareStatement(deleteSql);
                //执行sql语句
                resultSet = preparedStatement.executeQuery();
                while (resultSet.next()) {
                    User user = new User();
                    user.setId(resultSet.getLong(1));
                    user.setName(resultSet.getString(2));
                    user.setPassword(resultSet.getString(3));
                    user.setEmail(resultSet.getString(4));
                    user.setBirthday(resultSet.getDate(5));
                    user.setIntroduction(resultSet.getBlob(6));
                    user.setCreateAt(resultSet.getTimestamp(7).toLocalDateTime());
                    System.out.println(user);
                }

                //提交事务
                connection.commit();
            }
        } catch (SQLException e) {
            e.printStackTrace();
            try {
                //异常回滚
                connection.rollback();
            } catch (SQLException sqlException) {
                sqlException.printStackTrace();
            }
        } finally {
            //关闭连接
            JdbcUtils.release(resultSet,preparedStatement,connection);
        }
    }

    public static void batch() {
        Connection connection = JdbcUtils.getConnection();
        PreparedStatement preparedStatement = null;
        try {
            if (Objects.nonNull(connection)) {
                //手动提交事务
                connection.setAutoCommit(false);
                //创建预编译sql语句
                String insertSql = "insert into users(name,password,email,birthday) value(?,?,?,?)";
                preparedStatement = connection.prepareStatement(insertSql);
                for (int i = 0; i < 1000; i++) {
                    preparedStatement.setString(1,String.join("_","mysql",Integer.toString(i)));
                    preparedStatement.setString(2,"123456");
                    preparedStatement.setString(3,"[email protected]");
                    preparedStatement.setDate(4, new Date(System.currentTimeMillis()));
                    preparedStatement.addBatch();
                }

                //执行sql语句
                preparedStatement.executeBatch();
                //提交事务
                connection.commit();
            }
        } catch (SQLException e) {
            e.printStackTrace();
            try {
                //异常回滚
                connection.rollback();
            } catch (SQLException sqlException) {
                sqlException.printStackTrace();
            }
        } finally {
            //关闭连接
            JdbcUtils.release(null,preparedStatement,connection);
        }
    }
}

标签:语句,事务,JDBC,编程,try,connection,preparedStatement,sql
From: https://www.cnblogs.com/52-IT-y/p/17185876.html

相关文章

  • Java网络编程
    一、Java网络编程网络编程是指编写运行在多个设备(计算机)的程序,设备通过网络连接起来。java.net包中J2SE的API包含有类和接口,提供了低层次的通信细节。可以直接使用这些类和接口,来专注于解决问题,而不用关注通信细节。协议:计算机网络中,连接和通信的规则被称为网络通信协议1.UDP......
  • linux shell 编程比较详解
    shell编程字符串比较shell中整数比较和字符串比较方法,如等于,不等于,大于,大于等于,小于,小于等于等。1、整数比较-eq等于,如if["$a"-eq"$b"]-ne不等于,如if["$a"-ne"$b"]-gt大于,如if["$a"-gt"$b"]-ge大于等于,如if["$a"-ge"......
  • socket网络编程(一)——初识socket
    出现一项技术,首先我们弄懂一下,为什么要出现。那么为什么要出现socket这玩意呢?可以很简单的用一句话来概括:为了实现两台计算机的通信1、socket诞生的原因两台装有操作系统的机子要想实现通信,第一要联网,第二通信双方一定制定某种规则。我们平时最为常见的http请求也是一种通信协......
  • 【雕爷学编程】Arduino动手做(115)---HB100多普勒雷达模块
    37款传感器与执行器的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里准备逐一动手尝试系列实验,不管成功(程序走通)与否,都会记录下来—小小的进步或是搞......
  • go语言tcp编程学习
    TCP编程1、网络编程分类包括TCPsocket编程(底层基于tcp/ip协议)和b/s结构的http编程(使用的是http协议,但是底层是tcpsocket实现的)资料:尚硅谷的TCP资料(3卷),可以咸鱼找下资料看下2TCPsocket编程windows查看端口密码:netstat-anb;netstat-an服务器端的处理流程监听端口;接受......
  • 模板元编程之类模板(一)
    一、类模板Stack的实现#include<iostream>#include<vector>template<typenameT>classStack{private:std::vector<T>elems;//存储元素的容器public:voidpush(Tconst&);//压入元素voidpop();//弹出元素Ttop()const;//返回栈顶元素......
  • Spring — JdbcTemplate
    Spring—JdbcTemplateJdbcTemplate做持久层的操作导入包aop、ccbe(四核心)、spring-jdbc、c3p0、mysql-connector-java配置数据源编写数据库配置文件db.properties(driver、url、user、pwd)mysql5:Class.forName("com.mysql.jdbc.Driver");Stringurl="......
  • 【C】专家编程 (Expert C Programming) 阅读笔记
      第一章C:穿越时空的迷雾  1p22~24 ANSIC有此问题。“安静”的类型转换原则:当执行算术运算时,操作数的类型如果不同,就会发生转换。数据类型一般朝着浮点精度更高,长度更长的方向转换,整形术如果转换为singed不会丢失信息,就转换为signed,否则转换为unsign......
  • 关于如何使用C++进行编程(不使用数据库的情况下)
    问题描述对于一个长期使用Java连接数据库,实现javaweb编程的软工友友来说,突然在编程任务中不允许连接数据库,就有一点的蒙圈,没有办法,只能去查阅资料啦!问题解决不出意外的话,这次我们就需要使用文件操作来存储数据啦!(然后另外一种方法时json,显然,文件操作更加简单一点、也是更加熟悉......
  • 【雕爷学编程】Arduino动手做(114)---US-015高分辨超声波模块
    37款传感器与执行器的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里准备逐一动手尝试系列实验,不管成功(程序走通)与否,都会记录下来---小小的进步或是......