JDBC(java database connection)

2024-08-26 09:52
文章标签 java jdbc connection database

本文主要是介绍JDBC(java database connection),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JDBC介绍

java database connection   Java数据库连接

Java程序连接数据库的api(类,接口)

Java可以连接不同的数据库,但是不同的数据库具体的连接细节不同,因此连接数据库的细节应该由数据库开发商实现

由Java设计出一系列连接数据库的接口规范,然后由不同的数据库开发商去实现

interface oper{insert();delete();select();update();
}
//mysql实现连接数据库的功能
mysqlOperImpl implements oper{insert();delete();select();update();
}

由mysql官方开发实现,具体连接数据库的功能代码

JDBC步骤

1.在项目下创建lib文件夹,添加jar文件

2.加载驱动类

//加载驱动类有两种方法,两者选一个即可
Class.forName("com.mysql.cj.jdbc.Driver");
DriverManager.registerDriver(new Driver());

3.建立与数据库的连接,获得连接对象

//url格式:jdbc:mysql://ip(127.0.0.1):端口(3306)/数据库名?serverTimezone=Asia/Shanghai
String url = "jdbc:mysql://127.0.0.1:3306/schooldb?serverTimezone=Asia/Shanghai";
String user = "****";//****为mysql的账号名称
String password = "****";//此处为mysql的密码
Connection connection = DriverManager.getConnection(url, user,password);

4.发送sql

两种方法

PreparedStatement和Statement区别

相同点:都是向数据库发送sql

Statement: 将参数直接拼接到sql中,要求拼接字符串,写起来麻烦,安全性差,可以在参数中拼接or 1=1 会对数据库进行攻击。

delete(111 or 1=1);

例如

Statement st = connection.createStatement();
st.executeUpdate("insert into major(majorid_name) value ('数学')");

PreparedStatement: 先用?占位,然后通过setObject()方法赋值,写起来不用拼接字符,安全可靠的

在赋值时进行检测,可以防止sql被攻击

例如

PreparedStatement ps =  connection.prepareStatement("update student 
set name = ?,gender=?,brithday = ?,phone= ?,address=?
where num=?");//赋值ps.setObject(1, name);ps.setObject(2, gender);ps.setObject(3, brithday);ps.setObject(4, phone);ps.setObject(5, address);ps.setObject(6, num);

5.执行

5.1如果执行查询操作,接收包装查询结果

将查询结果封装到一个ResultSet对象中,需要将ResultSet对象中的数据封装到对应的对象中

并使用next()方法,判断结果中是否有数据,如果结果集中有数据返回true,否则返回false

ResultSet rs = ps.executeQuery();
while (rs.next()){//每循环一次,拿到一个学生对象Student student = new Student();student.setNum(rs.getInt("num"));//""内是查询的数据库列student.setName(rs.getString("name"));student.setGender(rs.getString("gender"));student.setBirthday(rs.getDate("brithday"));//获取年月日student.setPhone(rs.getString("phone"));student.setRegTime(rs.getTimestamp("reg_time"));//获取时间戳students.add(student);//将学生对象存入学生集合中
}

5.2如果执行增,删,改操作,使用  ps.executeUpdate();  使sql语句执行

6.关闭数据库连接

使用close()关闭

ps.close();
connection.close();

这种方法比较麻烦,可以使用maven来进行JDBC,第一步可在pom.xml中添加下面内容,配置项目中依赖的jar坐标

    <dependencies><!--mysql--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.16</version></dependency></dependencies>

之后的步骤于上述一致。

这篇关于JDBC(java database connection)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1108227

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

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