详解JDBC编程六步附模板代码


前言

本文详细介绍了JDBC的编程的六个步骤。首先来回顾一下JDBC的六步:

  1. 注册驱动
  2. 获取数据库连接
  3. 获取数据库操作对象
  4. 执行SQL语句
  5. 处理查询结果
  6. 释放资源

一、注册驱动

  • 需要掌握注册驱动的常用的两种方式
  1. Class.forName("com.mysql.jdbc.Driver");
    该方法最常用,因为参数是字符串,字符串可以写在xxxx.properties中
  2. System.setProperty("jdbc.drivers","com.mysql.cj.jdbc.Driver");
    该方法可以导入多个jdbc驱动,中间用冒号:隔开
    例如:System.setProperty("jdbc.drivers","XXXDriver:XXXDriver:XXXDriver");

二、获取数据库连接

  • 语句
connection = DriverManager.getConnection(url, user, password);
/*getConnection(String url, String user, String password) 
试图建立到给定数据库 URL 的连接。* /
  • 什么是url?
url:统一资源定位符(网络中某个资源的绝对路径)
                包括:
                    1.协议
                    2.ip
                    3.port
                    4.资源名
                 举例:https://220.181.38.149:80/index.html
                    https://        通讯协议
                    220.181.38.149  服务器ip地址
                    80              服务器上软件的端口号
                    index.html      服务器上的某个资源

            jdbc:mysql://localhost:3306/newsmanagersystem
                   jdbc:mysql://        协议:通信协议之前就定义好的数据传送格式,即数据包具体怎么传数据
                    localhost           ip地址(localhost和127.0.0.1都是本机IP)
                    3306                mysql数据库端口号
                    newsmanagersystem   具体的数据库实例名
  • 注意:需要明确传递的三个参数是什么!!

三、获取数据库操作对象

  • 语句
statement = connection.createStatement();
//调用createStatement()方法创建数据库操作对象

四、执行SQL语句

  • 语句
statement.executeUpdate("sql语句");//执行INSERT、UPDATE 或 DELETE 语句,返回int
resultSet = statement.executeQuery("sql语句");//执行select,返回查询结果集
           

五、处理查询结果集

  • 语句
boolean flag = resultSet.next();//光标指向的行,true为有数据,false无数据
              //  遍历输出查询结果集
            while (flag) {
                //取数据,这里的1,2,3指的是第几列,也可以写成列名(即查询结果集的列明,不是表中的列名称)
                //getString()方法的特点:不管数据库中的数据类型是什么,都以string的类型输出
                //除了string类型取出外,也可以使用特定的类型取出,但需要视情况而定
                String ntitle = resultSet.getString(1);
                String ncreateDate = resultSet.getString("data");
                String ncontent = resultSet.getString(3);
            }

六、关闭连接

  • 语句
 //6.释放资源
            if (resultSet != null) {
                try {
                    resultSet.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
                if (statement != null) {
                    try {
                        statement.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                    if (connection != null) {
                        try {
                            connection.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }

                    }

                }
            }
  • 注意:为了保证资源一定释放,在finally语句块中关闭资源, 并且要遵循从小到大依次关闭,分别对其try,catch。

七、模板代码

import java.sql.*;

/**
 * 回顾jdbc的六步
 * 1.注册驱动           掌握常用的两种方式
 * 2.获取数据库连接      connection=DriverManager.getConnection(url,user,password)明确三个参数是什么
 * 3.获取数据库操作对象   获取数据库连接对象connection后,就可以通过connection.createStatement()获取数据库操作对象statement
 * 4.执行SQL语句        拿到数据库操作对象statement后,就可以通过statement对象调用两种方法 1.executeUpdate() 2.executeQuery()  注意两种方法的返回值类型
 * 5.处理查询结果       只针对executeQuery()方法查询后的结果集resultSet
 * 6.释放资源
 */
public class JDBCtemplate {
    public static void main(String[] args) {
        Connection connection = null;
        Statement statement = null;
        ResultSet resultSet = null;//
        try {
            //1.注册驱动
            try {
                Class.forName("com.mysql.jdbc.Driver");//原理利用类加载机制
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
            //2.获取连接
            connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/newsmanagersystem", "root", "root");
            //3.获取数据库操作对象
            statement = connection.createStatement();
            //4.执行SQL语句
            statement.executeUpdate("");
            resultSet = statement.executeQuery("select ntitle,ncreateDate as data,ncontent  from news");
            //5.处理查询结果集
            boolean flag = resultSet.next();
              //  遍历输出查询结果集
            while (flag) {
                String ntitle = resultSet.getString(1);
                String ncreateDate = resultSet.getString("data");
                String ncontent = resultSet.getString(3);
            }

        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            //6.释放资源
            if (resultSet != null) {
                try {
                    resultSet.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
                if (statement != null) {
                    try {
                        statement.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                    if (connection != null) {
                        try {
                            connection.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }

                    }

                }
            }
        }
    }
}

总结

熟练掌握JDBC编程的6步,谢谢!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.1 Java语言发展简史2 1.2 认识Java语言3 1.2.1 Java语言特性3 1.2.2 JavaApplet4 1.2.3 丰富的类库4 1.2.4 Java的竞争对手5 1.2.5 Java在应用领域的优势7 1.3 Java平台的体系结构7 1.3.1 JavaSE标准版8 1.3.2 JavaEE企业版10 1.3.3 JavaME微型版11 1.4 JavaSE环境安装和配置12 1.4.1 什么是JDK12 1.4.2 JDK安装目录和实用命令工具介绍12 1.4.3 设置环境变量13 1.4.4 验证配置的正确性14 1.5 MyEcilpse工具介绍JavaSE环境安装和配置15 1.6 本章练习16 第2章 2.1 什么是程序18 2.2 计算机中的程序18 2.3 Java程序19 2.3.1 Java程序中的类型19 2.3.2 Java程序开发三步曲21 2.3.3 开发Java第一个程序21 2.3.4 Java代码中的注释23 2.3.5 常见错误解析24 2.4 Java类库组织结构和文档27 2.5 Java虚拟机简介28 2.6 Java技术两种核心运行机制29 2.7 上机练习30 第3章 3.1 变量32 3.1.1 什么是变量32 3.1.2 为什么需要变量32 3.1.3 变量的声明和赋值33 3.1.4 变量应用实例33 3.2 数据的分类34 3.2.1 Java中的八种基本数据类型34 3.2.2 普及二进制36 3.2.3 进制间转换37 3.2.4 基本数据类型间转换38 3.2.5 数据类型应用实例38 3.2.6 引用数据类型39 3.3 关键字.标识符.常量39 3.3.1 变量命名规范39 3.3.2 经验之谈-常见错误的分析与处理40 3.3.3 Java标识符命名规则41 3.3.4 关键字42 3.3.5 常量42 3.4 运算符43 3.4.1 算术运算符43 3.4.2 赋值操作符45 3.4.3 关系操作符47 3.4.4 逻辑操作符48 3.4.5 位操作符49 3.4.6 移位运算符49 3.4.7 其他操作符50 3.5 表达式52 3.5.1 表达式简介52 3.5.2 表达式的类型和值52 3.5.3 表达式的运算顺序52 3.5.4 优先级和结合性问题52 3.6 选择结构54 3.6.1 顺序语句54 3.6.2 选择条件语句54 3.6.3 switch结构59 3.6.4 经验之谈-常见错误的分析与处理65 3.6.5 Switch和多重if结构比较66 3.7 循环语句66 3.7.1 While循环67 3.7.2 经验之谈-常见while错误70 3.7.3 do-while循环72 3.7.4 for循环74 3.7.5 经验之谈-for常见错误76 3.7.6 循环语句小结78 3.7.7 break语句79 3.7.8 continue语句82 3.8 JavaDebug技术84 3.9 本章练习85 第4章 4.1 一维数组90 4.1.1 为什么要使用数组90 4.1.2 什么是数组91 4.1.3 如何使用数组92 4.1.4 经验之谈-数组常见错误97 4.2 常用算法98 4.2.1 平均值,最大值,最小值98 4.2.3 数组排序102 4.2.3 数组复制103 4.3 多维数组105 4.3.1 二重循环105 4.3.2 控制流程进阶107 4.3.3 二维数组111 4.4 经典算法113 4.4.1 算法-冒泡排序113 4.4.2 插入排序115 4.5 增强for循环116 4.6 本章练习117 第5章 5.1 面向过程的设计思想120 5.2 面向对象的设计思想120 5.3 抽象121 5.3.1 对象的理解121 5.3.2 Java抽象思想的实现122 5.4 封装124 5.4.1 对象封装的概念理解124 5.4.2 类的理解125 5.4.3 Java模板创建125 5.4.4 Java中对象的创建和使用127 5.5 属性130 5.5.1 属性的定义130 5.5.2 变量131 5.6 方法132 5.6.1 方法的定义132 5.6.2 构造方法135 5.6.4 方法重载138 5.6.5 自定义方法138 5.6.6 系统提供方法139 5.6.7 方法调用140 5.6.8 方法参数及其传递问题144 5.6.9 理解main方法语法及命令行参数147 5.6.1 0递归算法147 5.7 this关键字148 5.8 JavaBean149 5.9 包150 5.9.1 为什么需要包?150 5.9.2 如何创建包151 5.9.3 编译并生成包:151

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值