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知识库]是你的最爱吗? JDBC

在这里插入图片描述

JDBC

概述

1、JDBC(Java DataBase Connectivity)java 数据库连接
2、是一种用于执行SQL语句的java API ,可以为多种关系型数据库提供统一访问,它由一组java语言编写的类和接口组成。
JDBC API:
供程序员调用的接口与类,集成在java.sql 包中
DriverManager类作用:管理各种不同的jdbc驱动;
Connection 接口 与特定数据库的连接
Statement 接口 执行sql
PreparedStatement 接口 执行sql
ResultSet 接口 接收查询结果

获取连接的方式

我们这里直接给出最终版的通用的连接方式:

首相我们需要有一个文件存放用户名,密码,以及连接地址和JDBC下MySQL下的driver
在这里插入图片描述
这个文件包含下面内容:
在这里插入图片描述
代码:
下面展示一些 内联代码片

// 1 读取配置文件中 的 4个基本信息
        InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("jdbc.properties");
        Properties pros = new Properties();
        pros.load(is);
        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);

这就成功连接到了数据库
在这里插入图片描述

进行封装使用

我们可以把连接数据库和资源关闭这些代码进行封装:
在这里插入图片描述
进行封装之后便可以直接调用:
实例如下:

//查询

        //1 获取连接
        Connection conn = Utility.getConnection();
        //2 预编译
        String sql="select id,username,password from admin where id=5 ";
        PreparedStatement ps = conn.prepareStatement(sql);
        //执行
        ResultSet rs = ps.executeQuery();
        if(rs.next()) {
            int id = rs.getInt(1);
            String username = rs.getString(2);
            String password = rs.getString(3);
            User user=new User(id,username,password);
            System.out.println(user);
        }
        //3 关闭资源
        Utility.closeResources(conn,ps,rs);

运行结果:
在这里插入图片描述

封装升级版查询返回一个集合

1:使用ORM编程思想,写出一个通用的方法,方便后期做查询使用

 public static <T> List<T> getTargetList(Class<T> calzz,String sql, Object... args){
        Connection conn = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        try {
            //1获取连接
            conn = Utility.getConnection();
            //2预编译sql
            ps = conn.prepareStatement(sql);
            //3填充占位符
            for (int i = 0; i < args.length; i++) {
                ps.setObject(i + 1, args[i]);
            }
            //4 执行
            rs = ps.executeQuery();
            //获取结果集的元数据:ResultSetmetaDate
            ResultSetMetaData rsmd = rs.getMetaData();
            //通过ResultSetMetaData获取结果集中的列数
            int columnCount = rsmd.getColumnCount();
            ArrayList<T> list = new ArrayList<>();
            while (rs.next()) {
                T t = calzz.newInstance();
                //处理结果集中每一行数据的每个列
                for (int i = 0; i < columnCount; i++) {
                    Object columnClassvalue = rs.getObject(i + 1);
                    //获取每个列名
                    String columnName = rsmd.getColumnName(i + 1);
                    //给User对象 columnClassName属性赋值,赋值为columnClassvalue :通过反射
                    Field  field = calzz.getDeclaredField(columnName);
                    field.setAccessible(true);
                    field.set(t, columnClassvalue);
                }
                list.add(t);
            }
            return list;
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            Utility.closeResources(conn, ps, rs);
        }
        return null;
    }
}

2:实例:调用查询方法

运行如下代码:

 String sql2="select id,username,password from admin where id>?";
        List<User> list = Utility.getTargetList(User.class, sql2, 4);
        list.forEach(System.out::println);

先看数据库中数据:
在这里插入图片描述
运行上述代码得出:
在这里插入图片描述

总结步骤

  1. 获取连接,连接到数据库
  2. 预编译Sql语句
  3. 填充占位符
  4. 执行
    1. 获取结果集的元数据:ResultSetmetaDate
    2. 通过ResultSetMetaData获取结果集中的列数
    3. 处理结果集中每一行数据的每个列
    4. 获取每个列名
    5. 给实例化对象的columnName属性赋值,赋值为columnValue :通过反射
    6. 把对象添加到集合中
    7. 返回一个集合
  5. 关闭资源

在这里插入图片描述
总结:两个字 “ 绝 ”

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-11-27 09:46:50  更:2021-11-27 09:47:16 
 
开发: 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 3:39:16-

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