IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> day_04 JDBC -> 正文阅读

[大数据]day_04 JDBC

1.JDBC
? ? Java DataBase Connectivity ?(java数据库链接),即链接数据库的API
? ? 是一个接口或抽象类。
? ? 注:API : Application Programming Intergace (应用程序接口),即函数库

? ? 作用:连接数据库与程序的工具

? ? 使用步骤:
? ? ? ? 第0步: 导包
? ? ? ? 第1步:注册驱动 (仅仅做一次)
? ?   第2步:建立连接(Connection)
? ?   第3步:创建运行SQL的语句对象(Statement)
? ?   第4步:运行语句
? ?   第5步:处理运行结果(ResultSet)
? ? ? ? 第6步:释放资源

? ? *格式固定
? ? ?第一个类封装
? ? ?第二个类工具包

? ? public class Jdbc {
? ? ? ? public static void main(String[] args) {

? ? ? ? ? ? ResultSet resultSet=null;
? ? ? ? ? ? Statement statement=null;
? ? ? ? ? ? Connection conn=null;

? ? ? ? ? ? try {
? ? ? ? ? ? ? ? conn=JdbcUtil.getConnection();
? ? ? ? ? ? ? ? //第3步:创建运行SQL的语句对象(Statement)
? ? ? ? ? ? ? ? String sql="select * from student";
? ? ? ? ? ? ? ? statement=conn.createStatement();
? ? ? ? ? ? ? ? //第4步:运行语句,得到结果集
? ? ? ? ? ? ? ? resultSet = statement.executeQuery(sql);
? ? ? ? ? ? ? ? //第5步:处理运行结果(ResultSet)
? ? ? ? ? ? ? ? while(resultSet.next()){
? ? ? ? ? ? ? ? ? ? System.out.println("索引打印"+resultSet.getString(2));
? ? ? ? ? ? ? ? ? ? System.out.println("标签打印"+resultSet.getString("name"));;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }catch (Exception e){
? ? ? ? ? ? ? ? e.printStackTrace();
? ? ? ? ? ? }
? ? ? ? ? ??
? ? ? ? ? ? finally {
? ? ? ? ? ? ? ? //优化的关闭资源
? ? ? ? ? ? ? ? JdbcUtil.closeResultSet(resultSet);
? ? ? ? ? ? ? ? JdbcUtil.closeResultSet(statement);
? ? ? ? ? ? ? ? JdbcUtil.closeResultSet(conn);
? ? ? ? ? ? }
? ? ? ? }
? ? }

? ? 工具包
? ? public class JdbcUtil {

? ? ? ? public static Connection getConnection() throws Exception {
? ? ? ? ? ? //第1步:注册驱动 (仅仅做一次)
? ? ? ? ? ? Class.forName("com.mysql.jdbc.Driver");
? ? ? ? ? ? //第2步:建立连接(Connection)
? ? ? ? ? ? Properties properties=new Properties();
? ? ? ? ? ? properties.load(JdbcUtil.class.getClassLoader().getResourceAsStream("jdbc.properties"));
? ? ? ? ? ? String url = properties.getProperty("url");
? ? ? ? ? ? String username = properties.getProperty("username");
? ? ? ? ? ? String password = properties.getProperty("password");
? ? ? ? ? ? return DriverManager.getConnection(url,username,password);
? ? ? ? }
? ? ? ??
? ? ? ? public static void closeResultSet(AutoCloseable autoCloseable){
? ? ? ? ? ? try {
? ? ? ? ? ? ? ? if(autoCloseable!=null){
? ? ? ? ? ? ? ? ? ? autoCloseable.close();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }catch (Exception e){
? ? ? ? ? ? ? ? e.printStackTrace();
? ? ? ? ? ? }
? ? ? ? }
? ? }

2.sql注入
? ? 通过恶意的sql命令非法获得或更改设计者不允许操作的数据!

3.事物
? ? 指访问并可能更新数据库中各种数据项的一个程序执行单元。

? ? 四大特性:ACID
? ? 原子性(atomicity)。一个事务是一个不可分割的工作单位,
? ? ? ? 事务中包括的操作要么都做,要么都不做。
? ? 一致性(consistency)。事务必须是使数据库从一个一致性状态
? ? ? ? 变到另一个一致性状态。一致性与原子性是密切相关的。
? ? 隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作
? ? ? ? 及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
? ? 持久性(durability)也称永久性(permanence),指一个事务一旦提交,
? ? 它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

4.连接池
? ? 存放常用数据库连接,提高效率

? ? 优点:
? ? ? ? 1.资源复用,避免频繁创建释放连接导致的大量性能开销,也增强了系统运行环境的平稳性
? ? ? ? 2.更快的响应速度,初始化过程中,连接池就已经船舰了若干连接对象放在池中,减少了响应时间
? ? ? ? 3.统一的连接管理,避免数据库连接遗漏,有超时强制回收设定,避免泄露资源 ?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-02-19 01:14:20  更:2022-02-19 01:14:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 0:09:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码