Java零基础教学文档第三篇:JDBC

这篇具有很好参考价值的文章主要介绍了Java零基础教学文档第三篇:JDBC。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

今日新篇章
【JDBC】
【主要内容】

  1. JDBC概述

  2. 使用JDBC完成添加操作

  3. 使用JDBC完成更新和删除

  4. DBUtils的简单封装

  5. 使用JDBC完成查询

  6. 使用JDBC完成分页查询

  7. 常用接口详解

  8. JDBC批处理

  9. SQL注入问题

  10. 事务处理解决转账问题

  11. 连接池

  12. 使用反射对DBUtils再次的封装

  13. BaseDAO的封装

【学习目标】
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

1. JDBC概述

1.1 什么是JDBC
JDBC(Java DataBase Connectivity)就是Java数据库连接,说白了就是用Java语言来操作数据库。原来我们操作数据库是在控制台使用SQL语句来操作数据库,JDBC是用Java语言向数据库发送SQL语句。
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

1.2 JDBC的原理
早期SUN公司的天才们想编写一套可以连接天下所有数据库的API,但是当他们刚刚开始时就发现这是不可完成的任务,因为各个厂商的数据库服务器差异太大了。后来SUN开始与数据库厂商们讨论,最终得出的结论是,由SUN提供一套访问数据库的规范(就是一组接口),并提供连接数据库的协议标准,然后各个数据库厂商会遵循SUN的规范提供一套访问自己公司的数据库服务器的API出现。SUN提供的规范命名为JDBC,而各个厂商提供的,遵循了JDBC规范的,可以访问自己数据库的API被称之为驱动!
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

JDBC是接口,而JDBC驱动才是接口的实现,没有驱动无法完成数据库连接!每个数据库厂商都有自己的驱动,用来连接自己公司的数据库。

当然还有第三方公司专门为某一数据库提供驱动,这样的驱动往往不是开源免费的!

1.3 程序员,JDBC,JDBC驱动的关系及说明
1.3.1 JDBC API
提供者:Sun公司

内容:供程序员调用的接口与类,集成在java.sql和javax.sql包中,如

DriverManager类 作用:管理各种不同的JDBC驱动

Connection接口

Statement接口

ResultSet接口

1.3.2 JDBC 驱动
提供者:数据库厂商

作用:负责连接各种不同的数据库

1.3.3 Java程序员
JDBC对Java程序员而言是API,对实现与数据库连接的服务提供商而言是接口模型。

1.3.4 三方关系
SUN公司是规范制定者,制定了规范JDBC(连接数据库规范)

数据库厂商微软、甲骨文等分别提供实现JDBC接口的驱动jar包

程序员学习JDBC规范来应用这些jar包里的类。
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

1.4 总结
简单地说,JDBC 可做三件事:与数据库建立连接、发送 操作数据库的语句并处理结果。
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

DriverManager :依据数据库的不同,管理JDBC驱动

Connection :负责连接数据库并担任传送数据的任务

Statement :由 Connection 产生、负责发送执行SQL语句

ResultSet:负责保存Statement执行后所产生的查询结果

2. JDBC操作数据库的步骤

2.1 总体步骤

  1. 加载一个Driver驱动

  2. 创建数据库连接(Connection)

  3. 创建SQL命令发送器Statement

  4. 创建SQL

  5. 通过Statement发送SQL命令并得到结果

  6. 处理SQL结果(select语句)

  7. 关闭数据库资源

ResultSet

Statement

Connection

2.2 详细步骤
2.2.1 加载驱动
加载JDBC驱动是通过调用方法java.lang.Class.forName(),下面列出常用的几种数据库驱动程序加载语句的形式 :

Class.forName(“oracle.JDBC.driver.OracleDriver”);//使用Oracle的JDBC驱动程序

Class.forName(“com.microsoft.JDBC.sqlserver.SQLServerDriver”);//使用SQL Server的JDBC驱动程序

Class.forName(“com.ibm.db2.JDBC.app.DB2Driver”);//使用DB2的JDBC驱动程序

Class.forName(“com.mysql.jdbc.Driver”);//使用MySql的JDBC驱动程序

2.2.2 创建数据库连接
与数据库建立连接的方法是调用DriverManager.getConnection(String url, String user, String password )方法

Connection conn=null;

String url=“jdbc:mysql://localhost:3306/whpowernode?useUnicode=true&useSSL=false&charsetUnicode=UTF8”;

String user=“root";

String password=“123456";

conn = DriverManager.getConnection(url, user, password);

2.2.3 创建Statement并发送命令
Statement对象用于将 SQL 语句发送到数据库中,或者理解为执行sql语句

有三种 Statement对象:

Statement:用于执行不带参数的简单SQL语句;

PreparedStatement(从 Statement 继承):用于执行带或不带参数的预编译SQL语句;

CallableStatement(从PreparedStatement 继承):用于执行数据库存储过程的调用。
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

2.2.4 处理ResultSet结果
ResultSet对象是executeQuery()方法的返回值,它被称为结果集,它代表符合SQL语句条件的所有行,并且它通过一套getXXX方法(这些get方法可以访问当前行中的不同列)提供了对这些行中数据的访问。

ResultSet里的数据一行一行排列,每行有多个字段,且有一个记录指针,指针所指的数据行叫做当前数据行,我们只能来操作当前的数据行。我们如果想要取得某一条记录,就要使用ResultSet的next()方法 ,如果我们想要得到ResultSet里的所有记录,就应该使用while循环。

ResultSet对象自动维护指向当前数据行的游标。每调用一次next()方法,游标向下移动一行。

初始状态下记录指针指向第一条记录的前面,通过next()方法指向第一条记录。循环完毕后指向最后一条记录的后面。
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

2.2.5 关闭数据库资源
作为一种好的编程风格,应在不需要Statement对象和Connection对象时显式地关闭它们。关闭Statement对象和Connection对象的语法形式为:

public void close() throws SQLException

用户不必关闭ResultSet。当它的 Statement 关闭、重新执行或用于从多结果序列中获取下一个结果时,该ResultSet将被自动关闭。

注意:要按先ResultSet结果集,后Statement,最后Connection的顺序关闭资源,因为Statement和ResultSet是需要连接是才可以使用的,所以在使用结束之后有可能其他的Statement还需要连接,所以不能先关闭Connection。

3. 准备工作

3.1 创建数据并创建student表
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

3.2 创建项目
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

3.3 创建lib目录并引入MYSQL驱动包
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

3.4 把lib包引入项目环境
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

4. 使用JDBC完成添加操作

4.1 步骤
Ø 加载MySQL的JDBC驱动

Ø 建立数据的连接

Ø 创建SQL命令的发送器

Ø 编写SQL

Ø 使用SQL命令发送器发送SQL命令并得到结果

Ø 处理结果

Ø 关闭数据库资源

4.2 代码
package com.bjpowernode.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class Test01Add {
// 驱动器路径
private static final String DRIVER = “com.mysql.jdbc.Driver”;
//连接数据库地址
private static final String URL = “jdbc:mysql://localhost:3306/whpowernode?useUnicode=true&useSSL=false&characterEncoding=UTF8”;
//数据库用户名
private static final String USER_NAME = “root”;
//数据库密码
private static final String USER_PASSWORD = “123456”;
public static void main(String[] args) throws ClassNotFoundException, SQLException {
// 加载JDBC访问Oracle的驱动
Class.forName(DRIVER);
// 建立和数据库的连接
Connection conn = DriverManager.getConnection(URL, USER_NAME, USER_PASSWORD);
// 创建SQL命令发送器
Statement stmt = conn.createStatement();
// 使用SQL命令发送器发送SQL命令并得到结果
String sql = “insert into student values(1,‘小刚’,32,‘男’,‘湖北省武汉市’)”;
int n = stmt.executeUpdate(sql);
// 处理结果
if (n > 0) {
System.out.println(“添加成功”);
} else {
System.out.println(“添加失败”);
}
// 关闭数据库资源
stmt.close();
conn.close();
}
}

4.3 URL详解
4.3.1 为什么要定义URL
Java和MySQL是厂商的,Java程序和MySQL数据库此时不在同一个进程下,此时Java程序需要向MySQL发送请求。

4.3.2 如何发送请求呢?
jdbc:mysql://localhost:3306/whpowernode?useUnicode=true&useSSL=false&characterEncoding=UTF-8

使用URL的方式发送

jdbc 主协议

mysql 子协议

localhost MySQL服务器的地址,如果服务器就是我自己的主机,那么定义localhost就可以了

3306 MySQL服务器的端口号

whpowernode MySQL数据库服务器的数据库名称

useUnicode=true Java和MySQL交互使用Unicode编码

useSSL=false Java和MySQL交互不使用安全层协议

characterEncoding=UTF-8 Java和MySQL交互的编码方式为UTF-8 【如果不设置会有乱码的】

4.4 查看数据库
Java零基础教学文档第三篇:JDBC,Java零基础教学文档,java,数据库,开发语言

4.4.1 一个URL由哪些部分组成
Ø 协议://服务器主机:端口/服务器路径?查询参数

Ø 协议 jdbc:mysql:

Ø 服务器主机 localhost

Ø 端口 3306

Ø 服务器路径 whpowernode

Ø 参数useUnicode=true&useSSL=false&characterEncoding=UTF8

5. 使用JDBC完成更新和删除

5.1 步骤
Ø 加载MySQL的JDBC驱动

Ø 建立数据的连接

Ø 创建SQL命令的发送器

Ø 编写SQL

Ø 使用SQL命令发送器发送SQL命令并得到结果

Ø 处理结果

Ø 关闭数据库资源

5.2 修改代码
package com.bjpowernode.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class Test02Update {
// 驱动器路径
private static final String DRIVER = “com.mysql.jdbc.Driver”;
//连接数据库地址
private static final String URL = “jdbc:mysql://localhost:3306/whpowernode?useUnicode=true&useSSL=false&characterEncoding=UTF8”;
//数据库用户名
private static final String USER_NAME = “root”;
//数据库密码
private static final String USER_PASSWORD = “123456”;
public static void main(String[] args) throws ClassNotFoundException, SQLException {
// 加载Oracle的JDBC驱动
Class.forName(DRIVER);
// 建立数据的连接
Connection conn=DriverManager.getConnection(URL, USER_NAME, USER_PASSWORD);
// 创建SQL命令的发送器
Statement stat=conn.createStatement();
// 编写SQL
String sql=“update student set name=‘小明’,age=23,sex=‘女’,address=‘武汉’ where id=1”;
// 使用SQL命令发送器发送SQL命令并得到结果
int res=stat.executeUpdate(sql);
// 处理结果
if(res>0){
System.out.println(“修改成功”);
}
else{
System.out.println(“处理失败”);
}
// 关闭数据库资源
stat.close();
conn.close();
}
}

5.3 删除代码
package com.bjpowernode.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class Test03Delete {
// 驱动器路径
private static final String DRIVER = “com.mysql.jdbc.Driver”;
//连接数据库地址
private static final String URL = “jdbc:mysql://localhost:3306/whpowernode?useUnicode=true&useSSL=false&characterEncoding=UTF8”;
//数据库用户名
private static final String USER_NAME = “root”;
//数据库密码
private static final String USER_PASSWORD = “123456”;
public static void main(String[] args) throws ClassNotFoundException, SQLException {
// 加载Oracle的JDBC驱动
Class.forName(DRIVER);
// 建立数据的连接
Connection conn=DriverManager.getConnection(URL, USER_NAME, USER_PASSWORD);
// 创建SQL命令的发送器
Statement stat=conn.createStatement();
// 编写SQL
String sql=“delete from student where id=1”;
// 使用SQL命令发送器发送SQL命令并得到结果
int res=stat.executeUpdate(sql);
// 处理结果
if(res>0){
System.out.println(“删除成功”);
}
else{
System.out.println(“删除失败”);
}
// 关闭数据库资源
stat.close();
conn.close();
}
}

6. DBUtils的简单封装

6.1 为什么要封装
从我们上面的代码大家可以看到,每一次写我们创建一个连接,创建一个发送SQL的对象,最后还要关闭,那么我们可以考虑把这重复的代码提取出来!

6.2 创建DBUtils封装代码
package com.bjpowernode.utils;

import java.io.Closeable;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DBUtils {
// 驱动器路径
private static final String DRIVER = “com.mysql.jdbc.Driver”;
// 连接数据库地址
private static final String URL = “jdbc:mysql://localhost:3306/whpowernode?useUnicode=true&useSSL=false&characterEncoding=UTF8”;
// 数据库用户名
private static final String USER_NAME = “root”;
// 数据库密码
private static final String USER_PASSWORD = “123456”;

/**
 * 静态加载驱动程序
 */
static {
    try {
        Class.forName(DRIVER);
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    }
}
/**
 * @return 连接对象
 */
public static Connection getConn() {
    try {
        return  DriverManager.getConnection(URL, USER_NAME, USER_PASSWORD);
    } catch (SQLException e) {
        e.printStackTrace();
        System.out.println("创建连接对象异常");
    }
    return null;
}

/**
 * 关闭资源
 */
public static void close(AutoCloseable closeable) {
    try {
        if (closeable != null) {
            closeable.close();
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
}

}

6.3 创建上面的工具类对象前面的代码进行改造
package com.bjpowernode.jdbc;

import com.bjpowernode.utils.DBUtils;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class Test01Add {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
Connection conn = DBUtils.getConn();
// 创建SQL命令发送器
Statement stmt = conn.createStatement();
// 使用SQL命令发送器发送SQL命令并得到结果
String sql = “insert into student values(1,‘小刚’,32,‘男’,‘湖北省武汉市’)”;
int n = stmt.executeUpdate(sql);
// 处理结果
if (n > 0) {
System.out.println(“添加成功”);
} else {
System.out.println(“添加失败”);
}
// 关闭数据库资源
DBUtils.close(stmt);
DBUtils.close(conn);
}
}

7. 使用JDBC完成查询

7.1 循环向student表里面插入20条数
package com.bjpowernode.jdbc;

import com.bjpowernode.utils.DBUtils;

import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Random;

public class Test01Add20 {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
Connection conn = DBUtils.getConn();
// 创建SQL命令发送器
Statement stmt = conn.createStatement();
// 使用SQL命令发送器发送SQL命令并得到结果
Random random=new Random();
for (int i = 1; i <=20 ; i++) {
Integer id=i;
String name=“小明”+i;
int age=random.nextInt(100);
String sex=random.nextBoolean()?“男”:“女”;
String address=“武汉”+i;

        String sql = "insert into student values("+i+",'"+name+"',"+age+",'"+sex+"','"+address+"')";
        int n = stmt.executeUpdate(sql);
        // 处理结果
        if (n > 0) {
            System.out.println("添加成功");
        } else {
            System.out.println("添加失败");
        }
    }
    // 关闭数据库资源
    DBUtils.close(stmt);
    DBUtils.close(conn);
}

}

7.2 查询
package com.bjpowernode.jdbc;

import com.bjpowernode.utils.DBUtils;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Test04Query {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
Connection conn = DBUtils.getConn();
// 创建SQL命令发送器
Statement stmt = conn.createStatement();
// 编写SQL
String sql=“select * from student”;
// 使用SQL命令发送器发送SQL命令并得到结果
ResultSet rs=stmt.executeQuery(sql);
// 处理结果
while(rs.next()){
int id=rs.getInt(1);
String name=rs.getString(2);
int age=rs.getInt(3);
String sex=rs.getString(4);
String address=rs.getString(5);
System.out.println(id+" “+name+” “+age+” “+sex+” "+address);
}
// 关闭数据库资源
DBUtils.close(rs);
DBUtils.close(stmt);
DBUtils.close(conn);
}
}

8. 使用JDBC完成分页查询

package com.bjpowernode.jdbc;

import com.bjpowernode.utils.DBUtils;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Test05QueryForPage {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
Connection conn = DBUtils.getConn();
// 创建SQL命令发送器
Statement stmt = conn.createStatement();
int pageNum=2; //页码
int pageSize=5;//每页显示的条数
// 编写SQL
String sql=“select * from student limit “+(pageNum-1)*pageSize+”,”+pageSize;
// 使用SQL命令发送器发送SQL命令并得到结果
ResultSet rs=stmt.executeQuery(sql);
// 处理结果
while(rs.next()){
int id=rs.getInt(1);
String name=rs.getString(2);
int age=rs.getInt(3);
String sex=rs.getString(4);
String address=rs.getString(5);
System.out.println(id+" “+name+” “+age+” “+sex+” "+address);
}
// 关闭数据库资源
DBUtils.close(rs);
DBUtils.close(stmt);
DBUtils.close(conn);
}
}文章来源地址https://www.toymoban.com/news/detail-805693.html

到了这里,关于Java零基础教学文档第三篇:JDBC的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【从零开始学习JAVA | 第三十三篇】File类

    目录 前言: File类: 构造方法: 常见成员方法: 总结:         本文我们将为大家介绍JAVA中一个比较使用的类:File类,他为我们提供了存储数据的功能,使得程序的数据不至于在运行结束之后就丢失,是一个很好的类。         File类是Java标准库中用于操作文件和目录

    2024年02月15日
    浏览(33)
  • 2023年Java核心技术面试第三篇(篇篇万字精讲)

    目录 六.  Java反射机制以及动态代理是基于什么原理  6.1 反射机制: 6.2 反射例子: 6.3 动态代理: 6.4 例子: 6.5 总结: 6.5.1 代理模式 6.5.1.1动态代理: *6.5.1.2 JDK动态代理: *6.5.1.3 cglib动态代理: 6.5.1.4 反射与动态代理原理 6.5.2 应用场景: 6.5.2.3 组成要素: 6.5.2.4 实现方式

    2024年02月12日
    浏览(37)
  • 【从零开始学习Java重要知识 | 第三篇】暴打ReentrantLock底层源码

    目录 前言: 前置知识:  什么是公平锁与非公平锁? 尝试自己构造一把锁: ReentrantLock源码: 加锁: 解锁: 总结:   在并发编程中,线程安全是一个重要的问题。为了保证多个线程之间的互斥访问和正确的同步操作,Java提供了一种强大的锁机制——ReentrantLock(可重入锁

    2024年01月20日
    浏览(33)
  • JDBC增删改查 头歌实践教学Java

       

    2024年02月04日
    浏览(39)
  • Vue基础第三篇

    1 checkebox:     -单选     -多选 2 radio     -单选 示例: 2.1 基本购物车 补充: 2.3加减数量版 v-model 之 lazy、number、trim lazy:等待input框的数据绑定时区焦点之后再变化 number:数字开头,只保留数字,后面的字母不保留;字母开头,都保留 trim:去除首位的空格 前后端要打通

    2024年02月08日
    浏览(33)
  • 网络基础(第三篇)子网掩码

    文章目录 一、IP地址 二、 子网掩码 IP地址是什么? 在网络中用来标识设备的具体地址,数据需要通过此进行寻址传输。   IP地址的组成: 网络部分: 用来标识一个网络。代表IP地址所属网络,处于高位; 主机部分: 用来区分一个网络内的不同主机,能唯一标识网段上的某台

    2024年02月04日
    浏览(25)
  • Oracle之 第三篇 PL/SQL基础

    目录 Oracle之  第三篇  PL/SQL基础 PL/SQL程序块  PL/SQL语言 PL/SQL的基本结构   PL/SQL块分类    一、PL/SQL语言 二、PL/SQL 常量 、变量    合法字符 数据类型 LOB  数据类型  属性类型   运算符 常量    PL/SQL常量 1 、变量的声明        2、属性类型 % type 变量赋值 %type和%rowtype区

    2024年02月02日
    浏览(44)
  • 第三篇 香橙派的外设开发基础(中)— 串口篇

    目录 一、OrangePi PC Plus的串口 1.开启OrangePi PC+用于通信的串口  🔖方法一 :修改/boot/orangepiEnv.txt  🔖方法二:通过orangepi-config 2.基于wiringPi的串口通信Demo1.c 二、Linux下的串口开发基础  1.Linux下的串口配置 2.Linux串口通信Demo2.c         根据官方的用户手册所描述,OrangeP

    2023年04月08日
    浏览(28)
  • 【MySQL基础|第三篇】--- 详谈SQL中的DQL语句

    个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【MySQL学习专栏】🎈 本专栏旨在分享学习MySQL的一点学习心得,欢迎大家在评论区讨论💌 DQL(Data Query Language) 是 数据库查询语言 ,用来查询数据库表中的记录。查询

    2024年02月07日
    浏览(31)
  • JAVA基础-JDBC

    本博客记录JAVA基础JDBC部分的学习内容 JDBC : JAVA链接数据库,是JAVA链接数据库的技术的统称,包含如下两部分: 1. JAVA提供的JDBC规范(即各种数据库接口)存储在java.sql 和 javax.sql中的api 2. 各个数据库提供的jar包 jar包的定义与使用 mac下MYSQL安装 MYSQL WORKBENCH工具使用 JDBC课程笔

    2024年02月10日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包