JDBC-常用API

在上一篇文章里介绍了JDBC的概念、产生原因及简单使用。本篇将介绍JDBC的常用API,包括Connection,Statement, ResultSet, PreparedStatement。

一、Connection

Connection是数据库的连接对象。有两个作用:(1)获取执行SQL的对象(2)管理事务

关于第(1)点,将会在后续介绍,这里介绍一下(2)管理事务的操作。

管理事务有三个主要的API:

setAutoCommit(boolean b);

commit();

rollback();

具体的使用的注释见下面的代码片段:

// 关闭自动提交:true为自动提交事务;false为手动提交事务,即为开启事务        connection.setAutoCommit(false);try {// 定义sqlString sql1 = "update user set phone = '666' where id = 1";String sql2 = "update user set phone = '666' where id = 2";// 获取执行sql的对象statement = connection.createStatement();// 执行更新语句statement.executeUpdate(sql1);// 若放开这一行,出现了异常,事务会回滚,相当于两条sql都没有执行int x = 9 / 0;statement.executeUpdate(sql2);// 提交事务connection.commit();} catch (Exception e) {// 回滚connection.rollback();e.printStackTrace();} finally {// 释放资源connection.close();statement.close();}
二、Statement

Statement是执行SQL的对象,作用也是用于执行SQL。常用的SQL有DDL, DML, DQL,有以下两个常用的API。

int executeUpdate(String sql); 执行DDL, DML语句,返回值是影响的行数;

ResultSet executeQuery(String sql); 执行DQL语句,返回值是结果集对象;

更新语句可以见(一)中的示例,返回值对象将在下一节介绍。

三、ResultSet

JDBC执行查询SQL的返回值。作用就是封装返回对象。主要API有如下两个

boolean next(); 判断是否还有有效的数据;

xxx getXxx(参数) 获取数据,getInt, getString等。对于参数,可以是int或是string类型的。当参数是int时,表示的是列的编号;参数是string时,表示的是列的名称。

        // 定义sqlString sql = "select * from user";// 获取执行sql的对象statement = connection.createStatement();// 执行更新语句ResultSet resultSet = statement.executeQuery(sql);while (resultSet.next()) {Long id = resultSet.getLong("id");String name = resultSet.getString("name");String gender = resultSet.getString("gender");String phone = resultSet.getString("phone");System.out.println(id + name + gender + phone);}// 释放资源connection.close();statement.close();
四、PreparedStatement

继承自Statement,预编译SQL语句并执行,预防SQL注入问题,且性能更高。

        // 定义sql,用?作为占位符表示查询的参数String sql = "select * from user where name = ? and phone = ?";// 需要传入sql作为参数PreparedStatement statement = connection.prepareStatement(sql);// 第一个参数表示第几个占位符,设置?的值statement.setString(1, "zs");statement.setString(2, "777");// 执行更新语句ResultSet resultSet = statement.executeQuery();while (resultSet.next()) {Long id = resultSet.getLong("id");String name = resultSet.getString("name");String gender = resultSet.getString("gender");String phone = resultSet.getString("phone");System.out.println(id + name + gender + phone);}// 释放资源resultSet.close();statement.close();connection.close();

 关于性能更高的原因:在获取PreparedStatement对象时,会将参数里的sql发送约MySQL服务器进行检查和编译,因此耗时的动作先完成了;而且如果sql的模板一样时,只需要进行一次检查和编译。

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

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

相关文章

76.乐理基础-打拍子-二连音、四连音

内容来源于:三分钟音乐社 上一个内容:八三、八六拍的三角形打法-CSDN博客 这里要先理解了三连音的知识。 关于多少连音的总方针,其实就是两句话,如下图中的内容:二连音与四连音实际上就是下图中第二句话里的第一部分…

mmdetection训练自己的数据集

mmdetection训练自己的数据集 这里写目录标题 mmdetection训练自己的数据集一: 环境搭建二:数据集格式转换(yolo转coco格式)yolo数据集格式coco数据集格式yolo转coco数据集格式yolo转coco数据集格式的代码 三: 训练dataset数据文件配置config…

高防ip适合防御网站和游戏类的攻击吗?

​  作为站长,要学会并承受得住网站外来攻击的压力,尤其是所属为 DDoS 攻击高发行业的网站类业务及游戏行业,是很容易被竞争对手或者一些伪黑客爱好者盯上的。 加上,有些站长并没有提前了解,就盲目进军了这两个行业&…

C语言算法(二分查找、文件读写)

二分查找 前提条件&#xff1a;数据有序&#xff0c;随机访问 #include <stdio.h>int binary_search(int arr[],int n,int key);int main(void) {}int search(int arr[],int left,int right,int key) {//边界条件if(left > right) return -1;//int mid (left righ…

SAP 物料读取基本数据文本与检验文本READ_TEXT

1. 读取基本数据文本 使用函数 READ_TEXT 2. 读取检验文本

聚道云软件连接器助力某软件科技有限公司实现人力资源信息自动化

客户介绍&#xff1a; 某软件科技有限公司是一家集软件研发、销售、服务于一体的综合性软件企业。公司业务遍布全球多个国家和地区&#xff0c;拥有众多员工。 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 客户痛点&#xff1a; 部门及人员信息分散…

PyTorch|保存与加载自己的模型

训练好一个模型之后&#xff0c;我们往往要对其进行保存&#xff0c;除非下次用时想再次训练一遍。 下面以一个简单的回归任务来详细讲解模型的保存和加载。 来看这样一组数据&#xff1a; xtorch.linspace(-1,1,50)xx.view(50,1)yx.pow(2)0.3*torch.rand(50).view(50,1) 画…

【HarmonyOS】深入了解 ArkUI 的动画交互以提高用户体验

从今天开始&#xff0c;博主将开设一门新的专栏用来讲解市面上比较热门的技术 “鸿蒙开发”&#xff0c;对于刚接触这项技术的小伙伴在学习鸿蒙开发之前&#xff0c;有必要先了解一下鸿蒙&#xff0c;从你的角度来讲&#xff0c;你认为什么是鸿蒙呢&#xff1f;它出现的意义又是…

解压方法之一 zip

文章目录 解压方法之一 zip语法参数参考实例仅保存文件名更多信息 解压方法之一 zip … _linux-beginner-zip: Linux zip命令的功能是用于压缩文件&#xff0c;解压命令为unzip。 通过zip命令可以将很多文件打包成.zip格式的压缩包&#xff0c;里面会包含文件的名称、路径、…

uView Avatar 头像

本组件一般用于展示头像的地方&#xff0c;如个人中心&#xff0c;或者评论列表页的用户头像展示等场所。 #平台差异说明 App&#xff08;vue&#xff09;App&#xff08;nvue&#xff09;H5小程序√√√√ #基本使用 通过src指定头像的路径即可简单使用&#xff0c;如果传…

性能分析与调优: Linux 实现 CPU剖析与火焰图

目录 一、实验 1.环境 2.CPU 剖析 3.CPU火焰图 一、实验 1.环境 &#xff08;1&#xff09;主机 表1-1 主机 主机架构组件IP备注prometheus 监测 系统 prometheus、node_exporter 192.168.204.18grafana监测GUIgrafana192.168.204.19agent 监测 主机 node_exporter192…

【AI视野·今日CV 计算机视觉论文速览 第284期】Fri, 5 Jan 2024

AI视野今日CS.CV 计算机视觉论文速览 Fri, 5 Jan 2024 Totally 62 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Computer Vision Papers Learning to Prompt with Text Only Supervision for Vision-Language Models Authors Muhammad Uzair Khattak, Muhammad F…

jenkins忘记admin密码

jenkins忘记admin密码&#xff0c;重置密码&#xff1a; 1.找打jenkins目录下面的config.xml [rootVM-0-15-centos .jenkins]# find ./* -name config.xml ./config.xml [rootVM-0-15-centos .jenkins]# pwd /root/.jenkins删除下面的这部分内容&#xff1a; [rootVM-0-15-c…

网站被篡改怎么办,如何进行有效的防护

随着互联网的飞速发展&#xff0c;信息传播的速度和范围得到了极大的提升。然而&#xff0c;这也为网页篡改行为提供了可乘之机。网页被篡改不仅会损害网站的形象&#xff0c;还可能对用户造成误导&#xff0c;甚至导致安全漏洞。因此&#xff0c;网页防篡改技术成为了网络安全…

Linux部署前后端项目

部署SpringBoot项目 创建SpringBoot项目 先确保有一个可以运行的springboot项目&#xff0c;这里就记录创建项目的流程了&#xff0c;可以自行百度。 命令行启动 2.1、在linux中&#xff0c;我是在data目录下新创建的一个project目录&#xff08;此目录创建位置不限制&…

智慧园区运维:1500路摄像头故障监控及多机房一体化运维

一、引言 随着智慧园区的快速发展&#xff0c;对园区内IT设施的运维管理提出了更高的要求。本解决方案旨在满足智慧园区对1500路摄像头故障监控及视频画面质量分析的需求&#xff0c;同时具备可扩充性&#xff0c;适应未来园区规模的不断扩大。通过监控易的解决方案&#xff0c…

【C++11】可调用对象

C中存在可调用对象&#xff08;callable objects&#xff09;的一个概念。其具体定义为&#xff1a; 1&#xff09;函数指针 2&#xff09;具有operator&#xff08;&#xff09;的类对象&#xff08;仿函数&#xff09; 3&#xff09;可以被转换为函数指针的对象 4&#xff09…

如何翻译整本书并制作为双语对照?

随着人工智能技术的快速发展&#xff0c;机器翻译已经不再是遥不可及的梦想。众多大互联网公司如谷歌、百度等都相继推出了免费的翻译工具&#xff0c;使得跨语言沟通变得触手可及。今年&#xff0c;数百家公司更是开发出大型AI语言模型&#xff0c;其中以ChatGPT 4引人瞩目&am…

外延炉及其相关的小知识

外延炉是一种用于生产半导体材料的设备&#xff0c;其工作原理是在高温高压环境下将半导体材料沉积在衬底上。 硅外延生长&#xff0c;是在具有一定晶向的硅单晶衬底上&#xff0c;生长一层具有和衬底相同晶向的电阻率且厚度不同的晶格结构完整性好的晶体。 外延生长的特点&am…

Java 8升级Java 11,升级必知要点!竟然有这些坑…

随着技术的不断进步&#xff0c;Java作为一种广泛使用的编程语言&#xff0c;其版本更新带来了许多新特性和性能提升。从Java 8升级到Java 11&#xff0c;是一个重要的转变&#xff0c;它不仅带来了新的编程范式&#xff0c;还引入了对现代软件开发的多项优化。然而&#xff0c…