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 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> JDBC:实现Java与数据库的连接 -> 正文阅读

[Java知识库]JDBC:实现Java与数据库的连接

JDBC:实现Java与数据库的连接

先了解重要的编程思想:ORM(object relational mapping)

即将数据库与JAVA的类一一映射(对应)

  1. 一个数据表对应一个Java类
  2. 表中的一条记录对应Java类的一个对象
  3. 表中的一个字段对应Java类的一个属性

写代码之前的准备工作:

1.要加依赖包(mysql依赖包)

2.IDEA也要连接数据库

将连接数据库的基本信息都放在配置文件中,我们通过读取配置文件的方式,来获取和数据库的连接。

那么这样做有什么好处?

  1. 实现解耦,数据与代码分离。如果之后想换数据库/换账号密码,直接在配置文件中改就可以了,清晰简单。
  2. 如果需要修改配置文件的信息,可以避免程序重新再打包。

??基本JDBC连接数据库的代码,可以直接复用

public void testConnection() throws Exception{
  //1.读取基本信息
  InputStream is = ConnectionTest.class.getClassLoader().getResource();
  Properties pros = new Properties();
  pros.load(is);
  
  //这些参数都写在配置文件(pom.xml) 里,读取就可以了
  String user = pros.getProperty("user");
  String password = pros.getProperty("password");
  String url = pros.getProperty("url");
  String driverClass = pros.getProperty("driverClass");
  
  //2.然后再加载驱动(注册驱动)
  Class.forName(driverClass);
  
  //3.再获取一个连接
 	Connection conn = DriverManager.getConnection(url,user,password);
  
  //4.好了可以写sql语句了,这里用?来代表占位符,?位置的内容之后再填写
  String sql = "insert into customers(name,email,birth)values(?,?,?)";
  PreparedStatement ps = conn.prepareStatement();
  
  //5.要开始解决 ? 了 ———— 开始填东西
  ps.setString(1,"xx");
  ps.setString(2,"xxxx@email.com");
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  java.util.Date date = sdf.parse("2002-08-01");
  ps.setDate(3,new Date(date.getTime()));
  
  //6.都写好了就可以执行啦,可以把返回的结果都放到结果集中
  ResultSet rs = ps.executeQuery();
  
  //7.查完了,别忘记关闭连接,然后释放资源(很重要!)
  ps.close();
  conn.close();
}

??没加 try 和 catch 和 finally 的代码

如果单纯使用Statement,会产生弊端:存在SQL注入的问题。

解决方式:使用PreparedStatement就可以了
在这里插入图片描述

JAVA与SQL对应数据类型转换表

JavaSQL
boolean.BIT
byteTINYINT
shortSMALLINT
intINTEGER
longBIGINT
StringCHAR,VARCHAR,LONGVARCHAR
byte arrayBINARY, VAR BINARY
java.sql.DateDATE
java.sql.TimeTIME
java.sql.TimestampTIMESTAMP

两种技术

JDBC结果集的元数据:ResultSetMetaData

获取列数:getColumnCount();

获取列的别名:getColumnLabel();

如果考虑事务

public void test() throws Exception(){
  
	//……
  //前面老样子,就省略不写了,但有个重要的!
  //我们要先取消对事务的自动提交(想想SQL)
  conn.setAutoCommit(false);
  
  //好了接下来写2个sql语句,模拟一下这是事务
  String sql1;
  String sql2;
  
  //那么现在有2个sql语句要执行,一起执行后……
  update(conn,sql1,"A");
  update(conn,sql2,"B");
  
  //最后再提交,此时前面2个语句肯定都是成功执行了,那么这样就是完成一个事务了
  conn.commit();
  
  //这样就可以保证都执行完了再提交了
  //记得关资源
  JDBCUtiles.closeResource(conn,ps);
}

ps: 如果有异常,就用rollback()回滚事务

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-02-05 21:35:51  更:2022-02-05 21:36:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 10:27:06-

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