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

相关文章

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Java如何用乘号来重复字符串的功能

《Java如何用乘号来重复字符串的功能》:本文主要介绍Java使用乘号来重复字符串的功能,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java乘号来重复字符串的功能1、利用循环2、使用StringBuilder3、采用 Java 11 引入的String.rep

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

SQL 外键Foreign Key全解析

《SQL外键ForeignKey全解析》外键是数据库表中的一列(或一组列),用于​​建立两个表之间的关联关系​​,外键的值必须匹配另一个表的主键(PrimaryKey)或唯一约束(UniqueCo... 目录1. 什么是外键?​​ ​​​​2. 外键的语法​​​​3. 外键的约束行为​​​​4. 多列外键​

SpringBoot中HTTP连接池的配置与优化

《SpringBoot中HTTP连接池的配置与优化》这篇文章主要为大家详细介绍了SpringBoot中HTTP连接池的配置与优化的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、HTTP连接池的核心价值二、Spring Boot集成方案方案1:Apache HttpCl

Spring Boot项目打包和运行的操作方法

《SpringBoot项目打包和运行的操作方法》SpringBoot应用内嵌了Web服务器,所以基于SpringBoot开发的web应用也可以独立运行,无须部署到其他Web服务器中,下面以打包dem... 目录一、打包为JAR包并运行1.打包为可执行的 JAR 包2.运行 JAR 包二、打包为WAR包并运行

Java进行日期解析与格式化的实现代码

《Java进行日期解析与格式化的实现代码》使用Java搭配ApacheCommonsLang3和Natty库,可以实现灵活高效的日期解析与格式化,本文将通过相关示例为大家讲讲具体的实践操作,需要的可以... 目录一、背景二、依赖介绍1. Apache Commons Lang32. Natty三、核心实现代

Spring Boot 常用注解整理(最全收藏版)

《SpringBoot常用注解整理(最全收藏版)》本文系统整理了常用的Spring/SpringBoot注解,按照功能分类进行介绍,每个注解都会涵盖其含义、提供来源、应用场景以及代码示例,帮助开发... 目录Spring & Spring Boot 常用注解整理一、Spring Boot 核心注解二、Spr

SpringBoot实现接口数据加解密的三种实战方案

《SpringBoot实现接口数据加解密的三种实战方案》在金融支付、用户隐私信息传输等场景中,接口数据若以明文传输,极易被中间人攻击窃取,SpringBoot提供了多种优雅的加解密实现方案,本文将从原... 目录一、为什么需要接口数据加解密?二、核心加解密算法选择1. 对称加密(AES)2. 非对称加密(R