JDBC使用

1. 导包

直接使用IDEA导入依赖包即可

新建一个lib,把jar包放在这里

2. 加载驱动

Class.forName("oracle.jdbc.driver.OracleDriver");

3. 创建Connection对象

连接数据库,从而获得Connection对象

String url = "jdbc:oracle:thin:@localhost:1521:ORCL";//具体的实例名可以查看自己的服务管理,有个
Connection conn = DriverManager.getConnection(url,"scott","tiger");//后面的两个参数分别为连接数据库的用户名和密码

PS:查看实例名

  1. 开始->运行->输入services.msc

  2. 找到服务

  3. 后面的就是我们的oracle数据库的实例名

4. 创建Statement对象

Statement stmt = conn.createStatement();
  • Statement: 普通语句类型,只能执行一条完整的语句
  • PreparedStatement: 预编译语句,它支持占位符“?”, 如:select * from emp WHERE ename LIKE ? and sal>?
  • CallableStatement: 支持存储过程的调用

PreparedStatementCallableStatement都是继承Statement,比Statement要强大

补充链接:

PreparedStatement的使用

CallableStatement的使用(待补充)

5. 执行SQL语句

//执行查询语句,会返回有个结果集ResultSet
ResultSet rs = stmt.executeQuery("select * from student");

6. 使用ResultSet获取数据库数据

//遍历结果集, 每次调用next方法时会使结集的游标后移,最初游标位于第一行之前
//Student累是我们写的一个bean类,就是把数据库中的每一条数据当作为一个对象,每一列都当作为Student类的属性
while (rs.next()){
//第循环一次封装一条记录
Student student = new Student();
student.setNum(rs.getInt("num"));
student.setName(rs.getString("name"));
//获取其它字段rs.getXxx("列名") Xxx表示相应的数据类型
//或者也可以re.getXxx(int columnNum) 参数为第几列
//如果不知道列的具体类型,也可以使用rs.getObject
}

oracle与java的类型对应

oracle java
varchar/varchar(2) String
int int
number double
date date

7. 关闭

依次关闭ResultSet Statement Connection

补充

  • 一般将连接方法和关闭方法封装为静态方法调用,连接方法和关闭方法封装在JdbcUtil工具类中

  • 开启数据库链接的三个参数一般我们不会更改,所以我们直接写死在资源文件里面

    1. 设置编码UTF-8,使用中文字符就会自动转为Unicode

    2. ResourceBundle文件一般要在src同目录,否则会出现java.lang.NoClassDefFoundError异常,代码如下

      jdbc.url = jdbc:oracle:thin:@localhost:1521:ORCL
      jdbc.driver = oracle.jdbc.driver.OracleDriver
      jdbc.username = stars
      jdbc.password = stars

      ResourceBundle bundle = ResourceBundle.getBundle("资源文件名");
    String s = bundle.getString("keyName");//getString("username")..
    }
  • 写一个Dao类,其中有update,save,delete,find等方法,从而实现对数据库的增删改查

JdbcUtil工具类:

package homework;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ResourceBundle; /**
* @author StarsOne
* @date Create in 2019/4/24 0024 22:18
* @description
*/
class JdbcUtil {
private static final String DRIVER = getValue("jdbc.driver");
private static final String URL = getValue("jdbc.url");
private static final String USERNAME = getValue("jdbc.username");
private static final String PASSWORD = getValue("jdbc.password"); static{
try {
//注册数据库驱动程序
Class.forName(DRIVER);
} catch (ClassNotFoundException e) {
System.err.println("注册数据库驱动程序失败。" + e.getMessage());
}
} /**
* 获取数据库连接
* @return 一个Connection
*/
public static Connection getConnection() {
try {
Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
return conn;
} catch (SQLException e) {
System.err.println("a获得数据连接失败。" + e.getMessage());
}
return null;
} /**
* 关闭
* @param conn
* @param stmt
* @param rs
*/
public static void close(Connection conn, Statement stmt, ResultSet rs) {
try {
//关闭数据库的资源的顺序最好与使用的顺序相反
if(rs != null){
rs.close();
}
if(stmt != null){
stmt.close();
}
if(conn != null){
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
} /**
* 读取属性文件中的信息
*
* @param key
* @return
*/
private static String getValue(String key) {
// 资源包绑定
ResourceBundle bundle = ResourceBundle.getBundle("jdbc");
return bundle.getString(key);
} public static void main(String[] args) {
System.out.println(getValue("jdbc.driver"));
System.out.println(getConnection());
}
}

StudentDao.java

我的代码还没有补全,使用的Statement语句

package homework;

import java.sql.Connection;
import java.sql.Date;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List; /**
* @author StarsOne
* @date Create in 2019/4/24 0024 22:24
* @description
*/
class StudentDao { /**
* 添加一个
* @param student
*/
public void save(Student student) {
String name = student.getName();
int num = student.getNum();
Connection connection = null;
Statement statement = null;
try {
connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //拼接SQL语句,把数据插入到数据库中
statement.execute("insert into STUDENT value(" + num + "," + name + ") ");
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtil.close(connection, statement, null);
}
} public void update(Student student) { } /**
* 删除指定编号的学生
* @param num
*/
public void delete(Integer num) { Connection connection = null;
Statement statement = null;
try {
connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //拼接SQL语句,把数据插入到数据库中
boolean flag = statement.execute("delete from STUDENT where num = " + num);
if (flag) {
System.out.println("删除成功!");
} else {
System.out.println("删除失败!");
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtil.close(connection, statement, null);
}
}
/**
* 主键查询
* @param number
*/
public void findByPK(Integer number) { Connection connection = null;
Statement statement = null;
ResultSet resultSet=null;
try {
connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //查询query,返回一个数据集
resultSet = statement.executeQuery("select * from STUDENT where num =" + number);
while (resultSet.next()) {
int num = resultSet.getInt("num");
String name = resultSet.getString("name");
String sex = resultSet.getString("sex");
int age = resultSet.getInt("age");
Date birthdate = resultSet.getDate("birthdate");
double grade = resultSet.getDouble("grade");
//新建一个对象
new Student(num, age, grade, name, sex, birthdate); }
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtil.close(connection, statement, resultSet);
}
} /**
* 查询全部
* @return
*/
public List<Student> findAll() {
List<Student> list = new ArrayList<>();
Connection connection = null;
Statement statement = null;
ResultSet resultSet=null;
try {
connection = JdbcUtil.getConnection(); statement = connection.createStatement(); //查询query,返回一个数据集
resultSet = statement.executeQuery("select * from STUDENT" );
while (resultSet.next()) {
int num = resultSet.getInt("num");
String name = resultSet.getString("name");
String sex = resultSet.getString("sex");
int age = resultSet.getInt("age");
Date birthdate = resultSet.getDate("birthdate");
double grade = resultSet.getDouble("grade");
//新建一个对象
list.add(new Student(num, age, grade, name, sex, birthdate));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtil.close(connection, statement, resultSet);
}
return list;
} }

oracle学习笔记(六) JDBC使用的更多相关文章

  1. Oracle学习笔记六 SQL常用函数

    函数的分类 Oracle 提供一系列用于执行特定操作的函数 SQL 函数带有一个或多个参数并返回一个值 以下是SQL函数的分类:

  2. Oracle学习笔记(六)

    八.函数 1.函数的作用 (1)方便数据的统计 (2)处理查询结果,让数据显示更清楚 2.函数分类(提供很多内置函数,也可自定义函数) (1)数值函数 平均值,四舍五入 a.四舍五入 表达式 roun ...

  3. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  4. java之jvm学习笔记六-十二(实践写自己的安全管理器)(jar包的代码认证和签名) (实践对jar包的代码签名) (策略文件)(策略和保护域) (访问控制器) (访问控制器的栈校验机制) (jvm基本结构)

    java之jvm学习笔记六(实践写自己的安全管理器) 安全管理器SecurityManager里设计的内容实在是非常的庞大,它的核心方法就是checkPerssiom这个方法里又调用 AccessCo ...

  5. Learning ROS for Robotics Programming Second Edition学习笔记(六) indigo xtion pro live

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...

  6. oracle学习笔记第一天

    oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字   1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...

  7. Typescript 学习笔记六:接口

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  8. python3.4学习笔记(六) 常用快捷键使用技巧,持续更新

    python3.4学习笔记(六) 常用快捷键使用技巧,持续更新 安装IDLE后鼠标右键点击*.py 文件,可以看到Edit with IDLE 选择这个可以直接打开编辑器.IDLE默认不能显示行号,使 ...

  9. Go语言学习笔记六: 循环语句

    Go语言学习笔记六: 循环语句 今天学了一个格式化代码的命令:gofmt -w chapter6.go for循环 for循环有3种形式: for init; condition; increment ...

  10. Oracle学习笔记——点滴汇总

    Oracle学习笔记——点滴汇总 http://www.botangdb.com/ Oracle GI = Grid Infrastructure = ASM + Cluster

随机推荐

  1. Extjs中数据导出到Excel

    1.前端代码(URL+前端传入参数) window.location.href="studnetMaintainAction!exportExcel"               ...

  2. Android 7.0 存储系统—Vold与MountService分析(三)(转 Android 9.0 分析)

    Android的存储系统(三) 回顾:前帖分析了Vold的main()函数和NetlinkManager的函数调用流程,截止到NetlinkHandler的创建和start()调用,本帖继续分析源码 ...

  3. WebWorker 中将已处理好的 VDOM 数据提交主线程渲染 DOM

    上篇文章讲了 WebWorker 的简单用法,其实网上很多类似的文章,我写的也比较垃圾.不会的建议可以网上看比较好点的资料. 这里我会先讲下我的大致思路.然后会贴上一堆不实用的垃圾代码供参考. Web ...

  4. EFCore动态切换Schema

    最近做个分库分表项目,用到schema的切换感觉还是有些坑的,在此分享下. 先简要说下我们的分库分表 分库分表规则 我定的规则是,订单号(数字)除以16,得出的结果为这个订单所在的数据库,然后他的余数 ...

  5. 使用 Premiere 制作视频简介

    Premiere 简介 经常上B站或其他视频网站,有很多个人制作的有趣视频.也会想要自己制作视频.目前网上常见的视频剪辑软件有很多种,神剪辑.爱剪辑.会声会影.EDIUS等.但在专业视频剪辑师中,使用 ...

  6. Asp.Net Core 轻松学-多线程之取消令牌

    前言     取消令牌(CancellationToken) 是 .Net Core 中的一项重要功能,正确并合理的使用 CancellationToken 可以让业务达到简化代码.提升服务性能的效果 ...

  7. openlayers4 入门开发系列之地图切换篇(附源码下载)

    前言 openlayers4 官网的 api 文档介绍地址 openlayers4 api,里面详细的介绍 openlayers4 各个类的介绍,还有就是在线例子:openlayers4 官网在线例子 ...

  8. Flutter 异常处理之图片篇

    背景 说到异常处理,你可能直接会认为不就是 try-catch 的事情,至于写一篇文章单独来说明吗? 如果你是这么想的,那么本篇说不定会给你惊喜哦~ 而且本篇聚焦在图片的异常处理. 场景 学以致用,有 ...

  9. 快速构建H5单页面切换应用

    在Web App和Hybrid App横行的时代,为了拥有更好的用户体验,单页面应用顺势而生,单页面应用简称`SPA`,即Single Page Application,就是只有一个HTML页面的应用 ...

  10. 发布基于Orchard Core的友浩达科技官网

    2018.9.25 日深圳市友浩达科技有限公司发布基于Orchard Core开发的官网 http://www.weyhd.com/. 本篇文章为你介绍如何基于Orchard Core开发一个公司网站 ...