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查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

MySQL底层文件的查看和修改方法

《MySQL底层文件的查看和修改方法》MySQL底层文件分为文本类(可安全查看/修改)和二进制类(禁止手动操作),以下按「查看方法、修改方法、风险管控三部分详细说明,所有操作均以Linux环境为例,需... 目录引言一、mysql 底层文件的查看方法1. 先定位核心文件路径(基础前提)2. 文本类文件(可直

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配