原生Jdbc获取库、表、字段

news/2024/5/19 0:49:28 标签: java, 数据库, sql, jdbc, 大数据

文章目录

    • 一、简介
      • 1、概述
      • 2、Jdbc获取连接
      • 3、执行器
    • 二、获取链接
      • 1、获取链接
      • 2、关闭连接
      • 3、Statement
      • 4、PrepatedStatement
      • 5、 ResultSet
      • 6、ResultSetMetaData
    • 三、执行SQL
      • 2.1 增/删/改
      • 2.2 查询
    • 四、获取库、表结构
      • 1、获取Catalog
      • 2、获取库列表
      • 3、获取表名
      • 4、获取字段


一、简介

1、概述

  • JDBC(Java Database Connectivity)是一个独立于特定数据库管理系统、通用的SQL数据库存取和操作的公共接口(一组API),定义了用来访问数据库的标准Java类库,(java.sql,javax.sql)使用这些类库可以以一种标准的方法、方便地访问数据库资源。
  • JDBC为访问不同的数据库提供了一种统一的途径,为开发者屏蔽了一些细节问题。
  • JDBC的目标是使Java程序员使用JDBC可以连接任何提供了JDBC驱动程序数据库系统,这样就使得程序员无需对特定的数据库系统的特点有过多的了解,从而大大简化和加快了开发过程。

在这里插入图片描述

2、Jdbc获取连接

在这里插入图片描述

  • 1、加载驱动
  • 2、建立连接
  • 3、创建Statement对象
  • 4、执行SQL
  • 5、关闭连接
java">String jdbcdriver = "";
String url = "";
String username = "";
String password = "";
String sql = "";
//    1、加载驱动
Class.forName(jdbcdriver);
//    2、建立连接
Connection conn = DriverManager.getConnection(url, username, password);
//    3、创建Statement对象
PreparedStatement ps = conn.prepareStatement(sql);
//    4、执行SQL
ps.executeQuery();
//    5、关闭连接
conn.close();
ps.close();
closeConn(conn, ps);

3、执行器

java.sql 包中有 3 个接口分别定义了对数据库的调用的不同方式:

  • Statement:用于执行静态 SQL 语句并返回它所生成结果的对象。
  • PrepatedStatement:SQL 语句被预编译并存储在此对象中,可以使用此对象多次高效地执行该语句。
  • CallableStatement:用于执行 SQL 存储过程

在这里插入图片描述

二、获取链接

1、获取链接

java"> //    1、加载驱动
 Class.forName(jdbcdriver);
 //    2、建立连接
 Connection conn = DriverManager.getConnection(url, username, password);

2、关闭连接

java">//    5、关闭连接
conn.close();
ps.close();
closeConn(conn, ps);
java">public static <T> void close(T... t) {
    for (T one : t) {
        if (one instanceof AutoCloseable) {
            try {
                ((AutoCloseable) one).close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

方式二:

java">/**
 * 
 * @Description 关闭资源操作
 * @author shkstart
 * @date 上午10:21:15
 * @param conn
 * @param ps
 * @param rs
 */
public static void closeResource(Connection conn,Statement ps,ResultSet rs){
	try {
		if(ps != null)
			ps.close();
	} catch (SQLException e) {
		e.printStackTrace();
	}
	try {
		if(conn != null)
			conn.close();
	} catch (SQLException e) {
		e.printStackTrace();
	}
	try {
		if(rs != null)
			rs.close();
	} catch (SQLException e) {
		e.printStackTrace();
	}
}

3、Statement

Statement:用于执行静态 SQL 语句并返回它所生成结果的对象。

但是使用Statement操作数据表存在弊端:

  • 问题一:存在拼串操作,繁琐
  • 问题二:存在SQL注入问题
java">// 1、加载驱动
Class.forName(driverClass);
// 2、获取连接
Connection conn = DriverManager.getConnection(url, user, password);
//	3、获取执行器
Statement st = conn.createStatement();
//	4、执行查询
ResultSet rs = st.executeQuery(sql);
//	5、获取结果集的元数据
ResultSetMetaData rsmd = rs.getMetaData();

4、PrepatedStatement

PrepatedStatement:SQL 语句被预编译并存储在此对象中,可以使用此对象多次高效地执行该语句。

  • 可以通过调用 Connection 对象的 preparedStatement(String sql) 方法获取 PreparedStatement 对象

  • PreparedStatement 接口是 Statement 的子接口,它表示一条预编译过的 SQL 语句

  • PreparedStatement 对象所代表的 SQL 语句中的参数用问号(?)来表示,调用 PreparedStatement 对象的 setXxx() 方法来设置这些参数. setXxx() 方法有两个参数,第一个参数是要设置的 SQL 语句中的参数的索引(从 1 开始),第二个是设置的 SQL 语句中的参数的值

使用PreparedStatement实现增、删、改操作

java">//通用的增、删、改操作(体现一:增、删、改 ; 体现二:针对于不同的表)
	public void update(String sql,Object ... args){
		Connection conn = null;
		PreparedStatement ps = null;
		try {
			//1.获取数据库的连接
			conn = JDBCUtils.getConnection();
			
			//2.获取PreparedStatement的实例 (或:预编译sql语句)
			ps = conn.prepareStatement(sql);
			//3.填充占位符
			for(int i = 0;i < args.length;i++){
				ps.setObject(i + 1, args[i]);
			}
			
			//4.执行sql语句
			ps.execute();
		} catch (Exception e) {
			
			e.printStackTrace();
		}finally{
			//5.关闭资源
			JDBCUtils.closeResource(conn, ps);
			
		}
	}

使用PreparedStatement实现查询操作

java">

5、 ResultSet

问题1:得到结果集后, 如何知道该结果集中有哪些列 ? 列名是什么?

​ 需要使用一个描述 ResultSet 的对象, 即 ResultSetMetaData

在这里插入图片描述

  • 查询需要调用PreparedStatement 的 executeQuery() 方法,查询结果是一个ResultSet 对象

  • ResultSet 对象以逻辑表格的形式封装了执行数据库操作的结果集,ResultSet 接口由数据库厂商提供实现

  • ResultSet 返回的实际上就是一张数据表。有一个指针指向数据表的第一条记录的前面。

  • ResultSet 对象维护了一个指向当前数据行的游标,初始的时候,游标在第一行之前,可以通过 ResultSet 对象的 next() 方法移动到下一行。调用 next()方法检测下一行是否有效。若有效,该方法返回 true,且指针下移。相当于Iterator对象的 hasNext() 和 next() 方法的结合体。

  • 当指针指向一行时, 可以通过调用 getXxx(int index) 或 getXxx(int columnName) 获取每一列的值。

    • 例如: getInt(1), getString(“name”)
    • 注意:Java与数据库交互涉及到的相关Java API中的索引都从1开始。
  • ResultSet 接口的常用方法:

    • boolean next()

    • getString()

    在这里插入图片描述

6、ResultSetMetaData

用于获取关于 ResultSet 对象中列的类型和属性信息的对象

java">ResultSetMetaData meta = rs.getMetaData( );
  • getColumnName(int column):获取指定列的名称。
  • getColumnLabel(int column):获取指定列的别名。
  • getColumnCount():返回当前 ResultSet 对象中的列数。
  • getColumnTypeName(int column):检索指定列的数据库特定的类型名称。
  • getColumnDisplaySize(int column):指示指定列的最大标准宽度,以字符为单位。
  • isNullable(int column):指示指定列中的值是否可以为 null。
  • isAutoIncrement(int column):指示是否自动为指定列进行编号,这样这些列仍然是只读的。

在这里插入图片描述

三、执行SQL

2.1 增/删/改

java">	//通用的增、删、改操作(体现一:增、删、改 ; 体现二:针对于不同的表)
	public void update(String sql,Object ... args){
		Connection conn = null;
		PreparedStatement ps = null;
		try {
			//1.获取数据库的连接
			conn = JDBCUtils.getConnection();
			
			//2.获取PreparedStatement的实例 (或:预编译sql语句)
			ps = conn.prepareStatement(sql);
			//3.填充占位符
			for(int i = 0;i < args.length;i++){
				ps.setObject(i + 1, args[i]);
			}
			
			//4.执行sql语句
			ps.execute();
		} catch (Exception e) {
			
			e.printStackTrace();
		}finally{
			//5.关闭资源
			JDBCUtils.closeResource(conn, ps);
			
		}
	}

2.2 查询

使用PreparedStatement实现查询操作

java">// 通用的针对于不同表的查询:返回一个对象 (version 1.0)
	public <T> T getInstance(Class<T> clazz, String sql, Object... args) {

		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		try {
			// 1.获取数据库连接
			conn = JDBCUtils.getConnection();

			// 2.预编译sql语句,得到PreparedStatement对象
			ps = conn.prepareStatement(sql);

			// 3.填充占位符
			for (int i = 0; i < args.length; i++) {
				ps.setObject(i + 1, args[i]);
			}

			// 4.执行executeQuery(),得到结果集:ResultSet
			rs = ps.executeQuery();

			// 5.得到结果集的元数据:ResultSetMetaData
			ResultSetMetaData rsmd = rs.getMetaData();

			// 6.1通过ResultSetMetaData得到columnCount,columnLabel;通过ResultSet得到列值
			int columnCount = rsmd.getColumnCount();
			if (rs.next()) {
				T t = clazz.newInstance();
				for (int i = 0; i < columnCount; i++) {// 遍历每一个列

					// 获取列值
					Object columnVal = rs.getObject(i + 1);
					// 获取列的别名:列的别名,使用类的属性名充当
					String columnLabel = rsmd.getColumnLabel(i + 1);
					// 6.2使用反射,给对象的相应属性赋值
					Field field = clazz.getDeclaredField(columnLabel);
					field.setAccessible(true);
					field.set(t, columnVal);

				}

				return t;

			}
		} catch (Exception e) {

			e.printStackTrace();
		} finally {
			// 7.关闭资源
			JDBCUtils.closeResource(conn, ps, rs);
		}

		return null;

	}

四、获取库、表结构

1、获取Catalog

java">/**
 * 获取catalog
 *
 * @param jdbcdriver 驱动类(DriverClass)(com.mysql.cj.jdbc.Driver)
 * @param url        地址(jdbc:mysql://10.20.30.40:3306)
 * @param username   用户名
 * @param password   密码
 */
public List<String> getCatalogs(String jdbcdriver, String url, String username, String password) throws ClassNotFoundException, SQLException {
    ArrayList<String> list = new ArrayList<>();
    //    1、加载驱动
    Class.forName(jdbcdriver);
    //    2、建立连接
    Connection conn = DriverManager.getConnection(url, username, password);
    try {
        DatabaseMetaData metaData = conn.getMetaData();
        ResultSet resultSet = metaData.getCatalogs();
        while (resultSet.next()) {
            String string = resultSet.getString("TABLE_CAT");
            list.add(string);
        }
    } catch (SQLException e) {
        e.printStackTrace();
    } finally {
        conn.close();
    }
    return list;
}

2、获取库列表

java">/**
 * 获取数据库
 *
 * @param jdbcdriver 驱动类(DriverClass)(com.mysql.cj.jdbc.Driver)
 * @param url        地址(jdbc:mysql://10.20.30.40:3306)
 * @param username   用户名
 * @param password   密码
 * @param catalogs   catalogs
 */
public List<String> getDatabase(String jdbcdriver, String url, String username, String password, String catalogs) throws ClassNotFoundException, SQLExcepti
    ArrayList<String> list = new ArrayList<>();
    //    1、加载驱动
    Class.forName(jdbcdriver);
    //    2、建立连接
    Connection conn = DriverManager.getConnection(url, username, password);
    try {
        DatabaseMetaData metaData = conn.getMetaData();
        ResultSet resultSet = metaData.getSchemas(catalogs, null);
        //  没有catalog可以采用下面这种方式
        //  ResultSet resultSet = metaData.getSchemas();
        while (resultSet.next()) {
            String string = resultSet.getString("TABLE_SCHEM");
            list.add(string);
        }
    } catch (SQLException e) {
        e.printStackTrace();
    } finally {
        conn.close();
    }
    return list;
}

3、获取表名

java">/**
 * 获取表
 *
 * @param jdbcdriver 驱动类(DriverClass)(com.mysql.cj.jdbc.Driver)
 * @param url        地址(jdbc:mysql://10.20.30.40:3306)
 * @param username   用户名
 * @param password   密码
 * @param catalogs   catalogs
 * @param database   数据库
 */
public List<String> getTables(String jdbcdriver, String url, String username, String password, String catalogs, String database) throws ClassNotFoundException, SQLException {
    List<String> list = new ArrayList<>();
    //    1、加载驱动
    Class.forName(jdbcdriver);
    //    2、建立连接
    Connection conn = DriverManager.getConnection(url, username, password);
    try {
        DatabaseMetaData metaData = conn.getMetaData();
        ResultSet tables = metaData.getTables(
                catalogs,
                database,
                "%",
                new String[]{"TABLE", "VIEW"});
        while (tables.next()) {
            String name = tables.getString("TABLE_NAME");
            list.add(name);
        }
    } catch (SQLException e) {
        e.printStackTrace();
    } finally {
        conn.close();
    }
    return list;
}

4、获取字段

java">/**
 * 获取字段
 *
 * @param jdbcdriver 驱动类(DriverClass)(com.mysql.cj.jdbc.Driver)
 * @param url        地址(jdbc:mysql://10.20.30.40:3306)
 * @param username   用户名
 * @param password   密码
 * @param catalogs   catalogs
 * @param database   库
 * @param table      表
 */
public List<JSONObject> getColumns(String jdbcdriver, String url, String username, String password, String catalogs, String database) throws ClassNotFoundException, SQLException {
    List<JSONObject> list = new ArrayList<>();
    //    1、加载驱动
    Class.forName(jdbcdriver);
    //    2、建立连接
    Connection conn = DriverManager.getConnection(url, username, password);
    try {
        DatabaseMetaData metaData = conn.getMetaData();
        ResultSet rs = metaData.getColumns(catalogs, database, table, "%");
        while (rs.next()) {
            JSONObject json = new JSONObject();
            //  列明
            json.put("columnName", rs.getString("COLUMN_NAME"));
            //  列类型
            json.put("typeName", rs.getString("TYPE_NAME"));
            //  列备注
            json.put("remarks", rs.getString("REMARKS"));
            list.add(json);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        conn.close();
    }
    return list;
}

http://www.niftyadmin.cn/n/455840.html

相关文章

es知识点 一

针对于es的语言的学习 es是由java编写的&#xff0c;restfull api httpjson 支持分布式存储&#xff0c;每个字段被索引&#xff0c;被搜索 基于lucene的强大的全文搜索能力 可以实时搜索和聚合分析&#xff0c;自动发现新的和失败的节点&#xff0c;重新组合和新平衡数据 es的…

PCB设计系列分享-LDO的布局布线指南

目录 概要 整体架构流程 技术名词解释 技术细节 小结 概要 “噪声问题” 这是每位电路板设计师都会听到的四个字。为了解决噪声问题&#xff0c;往往要花费数小时的时间进行实验室测试&#xff0e;以便揪出元凶&#xff0c;但最终却发现&#xff0c;噪声是由开关电源的布局不当…

6. 第六部分:性能优化和调试技巧

6.1 代码优化和性能测试 以下是一些常见的方法和工具可以帮助你进行优化和测试&#xff1a; 优化技巧&#xff1a; 减少重绘和重排&#xff1a;尽量避免频繁的DOM操作&#xff0c;可以通过使用文档片段&#xff08;DocumentFragment&#xff09;或离线DOM操作来减少页面的重绘…

Android Binder通信原理(二):servicemanager启动

源码基于&#xff1a;Android R 0. 前言 下图是android 8.0 之前binder 的软件框架&#xff0c;依赖的驱动设备是/dev/binder&#xff0c;binder机制的四要素分别是client、server、servicemanager和binder驱动。 对于android 8.0后的binder 和vndbinder依然同这个框架&#…

D. Survey in Class(贪心 + 分类讨论)

Problem - D - Codeforces Zinaida Viktorovna 的历史课上有 n 名学生。今天的作业包括 m 个主题&#xff0c;但是学生们准备时间很短&#xff0c;所以第 i 个学生只学习了从 li 到 ri &#xff08;包括&#xff09;的主题。 在课开始时&#xff0c;每个学生都将手举在 0 处。…

JDK自带的构建线程池的方式之newScheduleThreadPool

顾名思义newScheduleThreadPool是一个定时任务的线程池&#xff0c;这个线程池可以定时一定周期去执行任务&#xff0c;也可以实现延迟多久去执行任务一次。 newScheduleThreadPool方法实现展示 基于查看这个方法不难发现&#xff0c;该方法是基于ScheduledThreadPoolExecutor…

关于印发进一步改善护理服务行动计划(2023—2025年)的通知

目录 1、背景说明2、具体内容2.1 贴近患者2.2 贴近临床2.3 贴近社会 1、背景说明 2023年6月15日国家卫生健康委印发了《关于印发进一步改善护理服务行动计划&#xff08;2023—2025年&#xff09;的通知》。其实在这个之前&#xff0c;2022年4月29日&#xff0c;国家卫生健康委…

车间现场管理难!车间主管如何掌握管理进阶?

车间是企业的基本层&#xff0c;搞好车间现场管理&#xff0c;有利于企业增强竞争力&#xff0c;提高产品质量和员工素质&#xff0c;保证安全生产&#xff0c;而车间班组长是生产线的主要管理者&#xff0c;是直接“当家人”&#xff0c;对生产现场状况了如指掌&#xff0c;对…