高效掌握JDBC技术(一)(上)

简介: 高效掌握JDBC技术(一)

一、JDBC概述

JDBC:Java数据库连接技术


通过Java后台代码连接数据库对数据库内容进行增删改查

1、为什么要学习JDBC?

navicat也可以连接数据库对数据进行增删改查,但是并不能定制化用户数据,所以并不完全使用实战开发


但是JDBC可以通过后台的其他代码完整用户数据的定制化


2、JDBC涉及到的API

Driver:驱动接口 定义了Java如何与数据库建立连接

DriverManager 驱动管理工具类 管理驱动,可以用来获取数据库连接

Connection 连接接口 代表了Java和数据库的联系

PreparedStatement 发送SQL的工具接口 用来像数据库发送一条执行SQL

Resultset 结果集接口 用来接受查询SQL的执行结果

3、JDBC的特点

它是一个规范,不是一个实现

JDBC中只有接口,并没有提供实现

二、JDBC的编码步骤

1、navicat操作数据库的步骤

加载和启动软件

建立连接

打开新建查询,准备书写sql

书写SQL并执行

查看执行结果

关闭软件窗口

2、JDBC操作数据库的六大步

加载驱动

获取连接

书写SQL并准备发送SQL的工具

发送SQL

处理结果集(只限查询)

释放相关资源

3、JDBC的步骤实现

1.搭建开发环境


导入指定jar包

1.右键项目,新建一个名为lib的文件夹

2.将mysql-connector-java-8.0.23.jar复制到文件夹中

3.右键jar包,点击add as library


2.通过代码实现JDBC六大步

public class JDBCTest {
        //这里的抛出的异常应该包含驱动、连接、sql异常等
    public static void main(String[] args) throws  Exception{
        //1. 加载驱动,必须正确的在lib文件夹下导入jar包
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2. 获取连接
        //用户名
        String username = "root";
        //密码,是自己数据库的密码,不一定都是root
        String pwd = "root";
        //连接的url,只要修改问号前的数据库名为自己的即可(当前为2109)
        String url = "jdbc:mysql://localhost:3306/2109?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai";
        Connection conn = DriverManager.getConnection(url, username, pwd);
        //3. 准备发送SQL的工具
        //往学生表中添加一条学生信息
        String sql = "insert into t_student(stu_name,stu_age,stu_sex,stu_class,stu_place) VALUES('lisi',18,'男','二年级','新乡')";
        PreparedStatement ps = conn.prepareStatement(sql);
        //4. 发送执行SQL
        int n = ps.executeUpdate();//执行SQL,增删改返回受影响条数
        if(n>0){                   //实际上n就是navicat里插入时显示的受影响的行数
            System.out.println("添加成功");
        }else{
            System.out.println("添加失败");
        }
        //5. 结果集 略,查询操作才会用到
        //6. 释放资源
        ps.close();     //先关小的资源
        conn.close();   //后关大的资源
    }
}

三、 结果集的处理

ResultSet:结果集

底层原理:指针操作,类似Iterator迭代器

next():判断是否存有下一元素

getXxx(int类型的列的顺序,从1开始):获取某个字段的值

getXxx(“字段名”):获取某个字段的值

Xxx:表示字段的数据类型,首字母大写

指定字段名更常用,更清晰

        //前面两步的数据库的加载驱动以及连接省略
        //3. 准备发送sql
        String sql = "select * from t_student";
        PreparedStatement ps = conn.prepareStatement(sql);
        //4. 发送sql并执行
        ResultSet rs=ps.executeQuery();
        //5. 处理结果集
        while (rs.next()){//当拥有下一元素时,才进入循环
            //获取字段的值
            int stuId = rs.getInt(1);
            String stuName = rs.getString(2);
            int stuAge = rs.getInt(3);
            String stuSex = rs.getString("stu_sex");
            String stuClass = rs.getString("stu_class");
            String stuplace = rs.getString("stu_place");
            //输出查看
            System.out.println(stuId+" "+stuName+" "+stuAge+" "+stuSex+" "+stuClass+" "+stuplace);
        }
        //6. 释放资源   由于rs是在ps的基础上存在的,因此先关rs的资源
        rs.close();      
        ps.close();
        conn.close();
目录
相关文章
|
4月前
|
SQL Java 关系型数据库
探索Java数据库连接的奥秘:JDBC技术全攻略
探索Java数据库连接的奥秘:JDBC技术全攻略
64 8
|
6月前
|
Java 数据库连接 API
后端开发之用Mybatis简化JDBC的开发快速入门2024及数据库连接池技术和lombok工具详解
后端开发之用Mybatis简化JDBC的开发快速入门2024及数据库连接池技术和lombok工具详解
68 3
|
6月前
|
存储 设计模式 搜索推荐
早期javeweb技术 JSP JDBC JSTJ Servlet BooStrap(下)
早期javeweb技术 JSP JDBC JSTJ Servlet BooStrap(下)
38 1
|
6月前
|
XML 前端开发 Java
早期javeweb技术 JSP JDBC JSTJ Servlet BooStrap(上)
早期javeweb技术 JSP JDBC JSTJ Servlet BooStrap(上)
37 0
|
6月前
|
SQL Java 关系型数据库
探索Java数据库连接的奥秘:JDBC技术全攻略
【6月更文挑战第24天】Java的JDBC是连接数据库的标准,提供统一API访问多种数据库。本文涵盖JDBC的基本概念、核心组件(如DriverManager、Connection、Statement、PreparedStatement和ResultSet)和最佳实践。示例展示了如何用JDBC连接MySQL,执行查询并处理结果。最佳实践包括使用PreparedStatement防SQL注入,妥善管理资源,处理异常,使用事务以及优化性能。了解和掌握JDBC能提升数据库操作的效率和安全性。
46 0
|
6月前
|
SQL Java 关系型数据库
探索Java数据库连接的奥秘:JDBC技术全攻略
【6月更文挑战第24天】Java的JDBC是连接Java和数据库的标准,提供统一的API访问各种数据库。核心组件包括DriverManager(加载驱动和创建连接)、Connection(表示数据库连接)、Statement(执行SQL)和PreparedStatement(参数化查询,防止SQL注入)。
34 0
|
6月前
|
SQL Java 关系型数据库
Java与数据库连接技术JDBC关键核心之PreparedStatement以及SQL注入演示解决和原理
Java与数据库连接技术JDBC关键核心之PreparedStatement以及SQL注入演示解决和原理
43 0
|
6月前
|
缓存 监控 druid
对比各大数据库连接池技术-Jdbc-Dbcp-C3p0-Druid-Hikaricp
对比各大数据库连接池技术-Jdbc-Dbcp-C3p0-Druid-Hikaricp
81 0
|
7月前
|
SQL Java 数据库连接
Java从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
ava从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
|
7月前
|
SQL Java 关系型数据库
JDBC技术文章
JDBC技术文章