原生JDBC连接数据库案例教学

简介: 前言:我们在刚刚接触后端开发时,有没有思考过,怎么才能后java代码和数据库进行交互的呢?

原生JDBC连接数据库案例教学


前言:

我们在刚刚接触后端开发时,有没有思考过,怎么才能后java代码和数据库进行交互的呢?

正轨:

今天就带大家一起学习一下原生JDBC连接数据库

里面解析结果集说了两种:一种需要导入maven依赖:

<dependency>
    <groupId>commons-dbutils</groupId>
    <artifactId>commons-dbutils</artifactId>
    <version>1.6</version>
</dependency>

直接上代码:

public static void main(String args[]){
        Connection con = null;
        Statement sta = null;
        ResultSet rs = null;
        try {
            //1.注册驱动==》告诉指挥部有哪些造桥人可以调遣
            Class.forName("com.mysql.cj.jdbc.Driver");
            //这里是mysql为例   oracle的url ---"jdbc:oracle:thin:@localhost:1521:orcl"
            String url = "jdbc:mysql://127.0.0.1:3306/test_1.0";
            String user = "root";
            String pwd =  "root";
            //2.获得链接==》指挥部根据传入类型 调遣不同的造桥的人造桥
            con = DriverManager.getConnection(url,user,pwd);
            //3.创建Statement对象===》造车
            sta = con.createStatement();
            //4.执行SQL ==》运行SQL 有结果返回
            String sql="select * from user";
            rs = sta.executeQuery(sql);
            //5.处理结果
            while(rs.next()){
                int id = rs.getInt("id");
                String name = rs.getString("name");
                int age = rs.getInt("age");
                //String code = rs.getString("");
                System.out.println(id+"\t"+name+"\t"+age+"\t");
            }
            System.out.println("----------------华丽分割线------------------");
            //第五步处理结果还可以引入Dbutils工具包来解析结果
            QueryRunner queryRunner = new QueryRunner();
            List<User> list = queryRunner.query(con, sql, new BeanListHandler<>(User.class));
            list.forEach(x-> System.out.println(x));
        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        }finally {
            //6.关闭资源
            close(con,sta,rs);
        }
    }

其中,在结束时要关闭资源,防止资源浪费,这里封装了一个关闭资源方法,代码如下:

public static void close(Connection con , Statement sta , ResultSet rs){
        try {
            rs.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            sta.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            con.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

运行结果展示,代码如下:

/**
     * 运行结果展示:
     * 解析ResultSet结果
     * 1  df  222
     * 2  wang  22
     * ----------------华丽分割线------------------
     * 使用Dbutils来拿取数据库结果展示
     * User(id=1, name=df, age=222)
     * User(id=2, name=wang, age=22)
     */

结语:

这样就和数据库建立了连接,当然对于数据库的url,账号密码可以写在配置文件中,这样方便修改,本博客目的是讲一下原生JDBC怎么与数据库建立连接的,有什么问题留言呦!!有时间写一下Dbutils工具包QueryRuunner的常用方法.



相关文章
|
18天前
|
关系型数据库 MySQL 数据库连接
Unity连接Mysql数据库 增 删 改 查
在 Unity 中连接 MySQL 数据库,需使用 MySQL Connector/NET 作为数据库连接驱动,通过提供服务器地址、端口、用户名和密码等信息建立 TCP/IP 连接。代码示例展示了如何创建连接对象并执行增删改查操作,确保数据交互的实现。测试代码中,通过 `MySqlConnection` 类连接数据库,并使用 `MySqlCommand` 执行 SQL 语句,实现数据的查询、插入、删除和更新功能。
|
1月前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
10天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
62 25
|
15天前
|
存储 SQL 关系型数据库
服务器数据恢复—云服务器上mysql数据库数据恢复案例
某ECS网站服务器,linux操作系统+mysql数据库。mysql数据库采用innodb作为默认存储引擎。 在执行数据库版本更新测试时,操作人员误误将在本来应该在测试库执行的sql脚本在生产库上执行,导致生产库上部分表被truncate,还有部分表中少量数据被delete。
54 25
|
19天前
|
存储 运维 数据挖掘
虚拟化数据恢复—误还原快照导致虚拟机上数据库丢失的数据恢复案例
虚拟化数据恢复环境&故障: vmfs文件系统,存储的数据是SqlServer数据库及其他办公文件。 工作人员误将快照还原,导致了SqlServer数据库数据的丢失,需要恢复原来的SqlServer数据库文件。
55 22
|
5天前
|
SQL 关系型数据库 MySQL
数据库数据恢复——MySQL简介和数据恢复案例
MySQL数据库数据恢复环境&故障: 本地服务器,安装的windows server操作系统。 操作系统上部署MySQL单实例,引擎类型为innodb,表空间类型为独立表空间。该MySQL数据库没有备份,未开启binlog。 人为误操作,在用Delete命令删除数据时未添加where子句进行筛选导致全表数据被删除,删除后未对该表进行任何操作。
|
12天前
|
存储 NoSQL MongoDB
数据库数据恢复—MongoDB数据库迁移过程中丢失文件的数据恢复案例
某单位一台MongoDB数据库由于业务需求进行了数据迁移,数据库迁移后提示:“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
1月前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
134 7
|
1月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
64 2
|
1月前
|
数据库 Windows
SqlServer数据恢复—SqlServer数据库所在分区损坏的数据恢复案例
一块硬盘上存放的SqlServer数据库,windows server操作系统+NTFS文件系统。由于误操作导致分区损坏,需要恢复硬盘里的SqlServer数据库数据。

热门文章

最新文章