Apache——DBUtils

news2025/1/22 19:56:58

韩顺平 零基础30天学会Java

一、基本介绍

1、commons-dbutils是 Apache 组织提供的一个开源JDBC工具类库,它是对JDBC的封装,使用dbutils能极大简化jdbc编码的工作量

二、DbUtils类

1、QueryRunner类:该类封装了SQL的执行,是线程安全的。可以实现增、删、改、查、批处理
2、使用QueryRunner类实现查询
3、ResultSetHandler接口:改接口用于处理java.sql.ResultSet,将数据按照要求转换成另一种形式
在这里插入图片描述

三、使用DBUtils+数据库连接池(Druid)方式完成对表的操作

  • actor表
    在这里插入图片描述
public class DBUtils_Use {
    //测试查询到多行结果
    @Test
    public void testQueryMany() throws Exception {
        //1、得到连接
        Connection connection = Druid.getConnection();
        //使用DBUtils 类和接口,先引入DBUtils相关的jar,加入到本Project
        //3、创建QueryRunner
        QueryRunner queryRunner = new QueryRunner();
        //4、就可以执行相关的方法返回ArrayList 返回结果集
        // (1)query 方法就是执行sql语句,得到resultSet----封装到--->ArrayList集合中
        //(2)返回集合
        //(3)connection:连接
        // (4)sql:执行的sql语句
        // (5)new BeanListHandler<>(Actor.class):在将resultset-》actor对象-》封装到ArrayList
        //底层使用反射机制,去获取Actor类的属性然后进行封装
        // (6)1 就是给sql语句中的?赋值,可以有多个值,因为是可变参数
        //(7)底层的到的resultSet,会在query 关闭,之后不用再关闭
        String select = "select * from actor";
        List<Actor> list = queryRunner.query(connection, select, new BeanListHandler<>(Actor.class));
        System.out.println("输出集合信息");
        for (Actor actor : list) {
            System.out.println(actor);
        }

        //释放连接
        Druid.close(null, null, connection);
    }

    //测试查询到单行结果
    @Test
    public void testSingle() throws Exception {
        //1、得到连接
        Connection connection = Druid.getConnection();
        //2、创建QueryRunner
        QueryRunner queryRunner = new QueryRunner();
        //3、sql语句
        String select = "select * from actor where id=?";
        //因为知道返回的是单行记录,因此使用 BeanHandler
        Actor actor = queryRunner.query(connection, select, new BeanHandler<>(Actor.class), 3);
        System.out.println(actor);

        //释放资源
        Druid.close(null, null, connection);
    }

    //演示查询单行单列的情况
    @Test
    public void testScalar() throws Exception {
        //1、得到连接
        Connection connection = Druid.getConnection();
        //2、创queryRunner
        QueryRunner queryRunner = new QueryRunner();
        //3、组织sql
        String select = "select name from actor where id=?";
        //执行
        Object query = queryRunner.query(connection, select, new ScalarHandler(), 3);
        System.out.println(query);
        //释放资源
        Druid.close(null, null, connection);
    }

    //更新内容
    @Test
    public void update() throws Exception {
        //1、获得连接
        Connection connection = Druid.getConnection();
        //2、创建QueryRunner
        QueryRunner queryRunner = new QueryRunner();
        //3、组织sql语句
        String update = "UPDATE actor SET `name`=? WHERE id=?";
        //4、执行
        int updateRows = queryRunner.update(connection, update, "新小龙女", 4);
        //5、释放资源
        Druid.close(null, null, connection);
    }

    //删除内容
    @Test
    public void delete() throws Exception {
        //1、获得连接
        Connection connection = Druid.getConnection();
        //2、创建QueryRunner
        QueryRunner queryRunner = new QueryRunner();
        //3、组织sql
        String delete = "DELETE FROM actor WHERE id=3";
        //4、执行
        int deleteRows = queryRunner.update(connection, delete);
        System.out.println(deleteRows > 0 ? "成功" : "失败");
        //5、释放资源
        Druid.close(null, null, connection);

    }

    //增加内容
    @Test
    public void insert() throws Exception {
        //1、获得连接
        Connection connection = Druid.getConnection();
        //2、创建QueryRunner
        QueryRunner queryRunner = new QueryRunner();
        //3、组织sql
        String insert = "INSERT INTO actor VALUES(null,?,?,?,?)";
        //4、执行
        int insertRows = queryRunner.update(connection, insert, "张三", "男", "1999-08-24", "119");
        System.out.println(insertRows > 0 ? "成功" : "失败");
        //5、释放资源
        Druid.close(null, null, connection);
    }


}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python处理PDF:在PDF文档中插入页眉和页脚

在处理篇幅较长、结构复杂的PDF文档时&#xff0c;页眉和页脚的设计与插入就显得尤为重要。它们不仅扮演着美化文档、提升专业度的角色&#xff0c;更承担了导航指引、信息标注的重要功能。 页眉通常用于展示文档的标题或章节名称&#xff0c;有助于读者在翻阅过程中迅速定位所…

网工基础协议——IP地址

IP地址的概念&#xff1a; IP 地址是我们进行TCP/IP通讯的基础&#xff0c;每个连接到网络上的计算机都必须有一个!P地址。我们目前使用的IP地址是32位的&#xff0c;通常以点分十进制表示。例如:192.168.0.181。IP地址的格式为: IP地址 网络地址 主机地址 或者 |P地址主机地…

真正的检索高手,为什么可以“不检索”?还摸鱼| 秘塔AI

开篇震撼&#xff1a;揭秘秘塔AI搜索的革命性力量 在信息爆炸的时代&#xff0c;如何快速准确地找到所需信息成为了一项挑战。国际上的AI驱动搜索引擎Perplexity以其整合网络最新资讯的能力&#xff0c;为用户提供精确且权威的答案&#xff0c;显著提高了信息检索效率。 而今…

【简明图文教程】Node.js的下载、安装、环境配置及测试

文章目录 前言下载Node.js安装Node.js配置Node.js配置环境变量测试后言 前言 本教程适用于小白第一次从零开始进行Node.js的下载、安装、环境配置及测试。 如果你之前已经安装过了Node.js或删除掉了Node.js想重新安装&#xff0c;需要先参考以下博客进行处理后&#xff0c;再根…

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单视频处理实战案例 之九 简单视频卡通画效果

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单视频处理实战案例 之九 简单视频卡通画效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单视频处理实战案例 之九 简单视频卡通画效果 一、简单介绍 二、简单视频卡通画效果实现原理 三、简单视频卡通画效果…

YOLOv8改进 | 检测头篇 | 自研超分辨率检测头HATHead助力超分辨率检测(混合注意力变换器检测头)

一、本文介绍 本文给大家带来的改进机制是由由我本人利用HAT注意力机制&#xff08;超分辨率注意力机制&#xff09;结合V8检测头去掉其中的部分内容形成一种全新的超分辨率检测头。混合注意力变换器&#xff08;HAT&#xff09;的设计理念是通过融合通道注意力和自注意力机制…

记录一个Kafka客户端Offset Explore连不上的问题

我昨天把集群重装了一下&#xff0c;再连这个工具就连不上了&#xff08;你先把zk和kafka在集群启起来&#xff09;&#xff0c;报错截图如下&#xff1a; 英文翻译过来大概就是说遍历zk指定路径不存在&#xff0c;我还以为zk的问题&#xff0c;回去又把zk的文档翻了一遍&#…

物联网实战--驱动篇之(七)RTC时钟(DS1302)

目录 一、RTC简介 二、DS1302介绍 三、初始化 四、字节读写 五、功能函数 一、RTC简介 实时时钟&#xff0c;简称RTC&#xff0c;这个在STM32的外设里也有&#xff0c;不过STM32F1系列的RTC实际上只有一个计数器功能&#xff0c;如果需要年月日要自己写软件计算 &#xff…

C++/QT 医院信息管理系统

一、项目介绍 &#xff08;1&#xff09;管理员、居民、医生三个角色登录&#xff1b;居民可注册账号登录&#xff0c;医生由管理员添加&#xff0c;管理员权限最高 &#xff08;2&#xff09;管理员&#xff1a; 模块一&#xff1a;信息管理&#xff08;医生信息管理、医院…

Leetcode算法训练日记 | day23

一、修剪二叉搜索树 1.题目 Leetcode&#xff1a;第 669 题 给你二叉搜索树的根节点 root &#xff0c;同时给定最小边界low 和最大边界 high。通过修剪二叉搜索树&#xff0c;使得所有节点的值在[low, high]中。修剪树 不应该 改变保留在树中的元素的相对结构 (即&#xff…

基于级联H桥的多电平逆变器PWM控制策略的simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 级联H桥&#xff08;CHB&#xff09;多电平逆变器是一种通过多个H桥单元级联实现更高电压等级和更高质量输出波形的电力电子转换装置。这种逆变器在高压大功率场合应用广泛&am…

[CTF]使用浏览器firefox插件伪装IP地址

来源&#xff1a;https://jingyan.baidu.com/article/ab0b56306d9890c15bfa7d6a.html 浏览器想必是大家再熟悉不过的东东了&#xff0c;我们会经常使用它访问下载一些页面或文件。但是对于它的更深层次的功能可能就陌生了。比如说一些网站后台会记录我们的IP地址&#xff0c;假…

U盘怎么加密?U盘加密的方法有哪些?

U盘作为一种便携式的存储设备&#xff0c;广泛应用于日常生活和工作中。但由于其易于携带和使用的特性&#xff0c;U盘中的数据也面临着被未经授权访问的风险。因此&#xff0c;对U盘进行加密成为了保护数据安全的重要措施。本文将介绍几种常见的U盘加密方法&#xff0c;帮助用…

5G智慧港口简介(一)

引言 港口作为交通运输的枢纽,在促进国际贸易和地区发展中起着举足轻重的作用,全球贸易中约 90% 的贸易由海运业承载,作业效率对于港口至关重要。在“工业 4.0”、“互联网 +”大发展的时代背景下,港口也在进行数字化、全自动的转型升级。随着全球 5G 技术浪潮的到来,华为…

android android.permission.MANAGE_EXTERNAL_STORAGE使用

android11 及以上版本&#xff0c;如果release版本要读取外部存储公共目录&#xff0c;即sdcard公共目录&#xff0c;需要在androidManifest.xml下申明 <uses-permission android:name"android.permission.MANAGE_EXTERNAL_STORAGE" /> 如果要发版到海外&…

前端对接fastGPT流式数据+打字机效果

首先在对接api时 参数要设置stream: true, const data {chatId: abc,stream: true,//这里true返回流式数据detail: false,variables: {uid: sfdsdf,name: zhaoyunyao,},messages: [{ content: text, role: user }]}; 不要用axios发请求 不然处理不了流式数据 我这里使用fetch …

7.接口自动化测试-Allure报告

1.环境搭建 &#xff08;1&#xff09;下载并解压allure.zip&#xff0c;不要用中文路径&#xff0c;将bin目录配置到path环境变量 官网&#xff1a;Allure下载 &#xff08;2&#xff09;cmd安装allure-pytest第三方库 pip install allure-pytest 检测是否安装成功 pip show …

ollama与open-webui简单使用案例

参考: https://github.com/ollama/ollama https://github.com/open-webui/open-webui ollama最为大模型后端服务 open-webui前端聊天页面 ollama直接下载客服端安装win cpu安装推理;open-webui使用docker安装 1、ollama 安装好后可以直接运行,cpu使用不稳定比较慢 ollama…

Kimichat的浏览器插件Kimi Copilot:一键总结网页内容

在阅读网页的时候&#xff0c;如果需要总结网页内容要点&#xff0c;可以把链接丢进Kimichat&#xff0c;让它总结。但是&#xff0c;这样稍微有些麻烦。Chrome浏览器现在已经有一个非官方的Kimichat插件&#xff1a; Kimi Copilot - 网页总结助手&#xff0c;可以用Kimi AI一键…

【模板】费马小定理求逆元|快速幂、数论

题目&#xff1a; P1226 【模板】快速幂 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 下面这道题用费马小定理快速幂的结论的程序会TLE&#xff0c;且费马小定理需要互质和模数p为质数&#xff0c; 但是可以作为练习 P3811 【模板】模意义下的乘法逆元 - 洛谷 | 计算机…