当前位置: 首页 > article >正文

JDBC的概念

一.JDBC概念:


其实JDBC就像是翻译官,就像是你去到国外是不是听不懂当地人再讲什么?Java就相当于是你,数据库就是本地人,然后JDBC就是那个翻译官,它提供了一套标准的方法和工具,让Java程序可以与各种不同类型的数据库进行交流,无论是MySQL、Oracle、SQL Server还是其他类型的数据库。它隐藏了与具体数据库相关的细节,使得Java程序员可以用相同的方式来访问不同的数据库,而不需要去关心底层数据库的具体实现。通过JDBC,Java程序可以执行诸如连接数据库、发送SQL查询、获取查询结果等操作。它为Java程序提供了一个简单、灵活且可靠的方式来与数据库进行交互,从而实现数据的存储、检索和处理。

二.JDBC好处:


①各数据库厂商使用相同的接口,Java代码不需要针对不同数据库分别开发。
②可随时替换底层数据库,访问数据库的Java代码基本不变。

三.JDBC步骤:

1.注册驱动:

Class.forName("com.mysql.cj.jdbc.Driver");
注意:"com.mysql.cj.jdbc.Driver"是MySQL 8.0及以上版本的驱动类名。如果你使用的是旧版本的MySQL驱动,可能是"com.mysql.jdbc.Driver"。
2.获取连接:
Connection conn = DriverManager.getConnection(url, username, password);
3.定义SQL语句:
String sql = "UPDATE table_name SET column1 = value1 WHERE condition;";
这里需要将"UPDATE table_name SET column1 = value1 WHERE condition;"替换为你要执行的实际SQL语句。
3.
①获取执行SQL的对象:
Statement stmt = conn.createStatement();
②执行SQL:
stmt.executeUpdate(sql);
executeUpdate()方法用于执行INSERT、UPDATE或DELETE等操作。
4.处理返回结果:
// 对于UPDATE、INSERT或DELETE操作,通常不需要显式处理返回结果。
但如果需要处理查询结果,可以通过ResultSet对象来获取返回的数据。
5.释放资源:
stmt.close();
conn.close();

四.DriverManager(驱动管理类)作用:


①注册驱动
②获取数据库连接池

五.Connection(数据库连接对象)作用:

1.获取执行SQL的对象。2.管理事务。

Connection:获取执行SQL对象:

1.普通执行SQL对象:Statement  createStatement()

2.预编译SQL的执行SQL对象:防止SQL注入:PreparedStatement  PreparedStatement(sql)  

3.执行存储过程的对象:CallableStatement prepareCall(sql)

六.

ResultSet:executeQuery(sql):执行DQL语句    返回值:ResultSet结果集对象。

七.

Statement:1.执行SQL语句: int executeUpdate(sql):执行DML,DDL语句     返回值:1.DML语句影响的行数。

2.DDL语句执行后,执行成功也可能返回0

八.ResulySet:使用步骤:

1.游标向下移动一行,并哦按段改行是否有数据:next()   2.获取数据:getXxx(参数)                 //该循环判断游标是否最后一行结尾:while(rs.next(){          //2.获取数据  rs.getXxx(参数);                                            

}

九.JDBC事务管理:

connection接口中定义了三个对应的方法:

1.开启事务:setAutoCommit(boolean autoCommit):true为自动提交事务,false为手动提交事务,即为开启事务。

2.提交事务:commit()3.回滚事务:rollback()


http://www.kler.cn/a/272923.html

相关文章:

  • Web第一次作业
  • Java基础:equals()方法与==的区别
  • Elasticsearch:Jira 连接器教程第一部分
  • C++通透讲解设计模式:依赖倒转(1)
  • 神经网络基础-价格分类案例
  • C++单例模式的设计
  • C语言选择语句概览
  • 用python写网络爬虫:2.urllib库的基本用法
  • Android14之报错:error:add its name to the whitelist(一百九十四)
  • ✅技术社区—通过Canal框架实现MySQL与ElasticSearch的数据同步
  • 机器学习-绪论
  • SSH远程连接断开后,程序继续运行
  • 10:00面试,10:06就出来了,问的问题有点变态。。。
  • 【黑马程序员】Python高阶
  • VS Code安装Live Server插件搭建web网页结合内网穿透实现公网访问
  • matlab FR共轭梯度法求解无约束问题
  • 深度学习-2.8模型拟合概念和欠拟合模型、过拟合调整策略
  • vulhub中GIT-SHELL 沙盒绕过漏洞复现(CVE-2017-8386)
  • 寒假作业Day 13
  • 【C语言】打印闰年
  • 疯狂 META:Aavegotchi 新一季稀有度挖矿来了!
  • 【Linux网络编程七】网络序列化和反序列化(网络版本计算器)
  • 信息检索(十三):On Complementarity Objectives for Hybrid Retrieval
  • 基于单片机的灭火机器人设计
  • C 练习实例77-指向指针的指针-二维数组
  • 探秘atoi与atof的模拟之路:从原理到实践的全能指南!