Connection(数据库连接对象)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: Connection(数据库连接对象)

Connection(数据库连接对象

简介:通过代码来讲解Connection的含义。

推荐学习路线:JDBC数据库的连接->Connection(数据库连接对象)->Driud数据库连接池的使用->ResultSet->通过PreparedStatement预防SQL注入->JDBC增删改查案例讲解 大家跟着敲完基本就可以JDBC基础毕业了。

演示代码

/**
 * JDBC API 详解:Connection
 */
public class JDBCDemo_Connection {
    public static void main(String[] args) throws Exception {
       //1. 注册驱动
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2. 获取连接
        // String url = "jdbc:mysql://127.0.0.1:3306/books"; // 如果是mysql5这样写
        String url = "jdbc:mysql://localhost:3306/books?serverTimezone=GMT%2B8&useOldAliasMetadataBehavior=true"; // 如果是mysql8这样写
        String username = "root";
        String password = "1234";
        Connection conn = DriverManager.getConnection(url, username, password);
        //3. 定义sql
        String sql1 = "update book set price = price - 8 where reclD = 1";
        String sql2 = "update book set price = price - 8 where reclD = 2";
        String sql3 = "update book set price = price - 8 where reclD = 3";
        //4. 获取执行sql的对象 Statement
        Statement stmt = conn.createStatement();
        try {
            // ============开启事务==========
            conn.setAutoCommit(false); // 加上这几句之后 如果发生异常就会回滚 然后数据不会发生改变
                          // 如果没有发生异常 但是发现数据库里面的数据没有改变
                          // 可以把这里改成true 不改的话内存里面的数据改了 但是显示的没有改
            //5. 执行sql
            int count1 = stmt.executeUpdate(sql1);//受影响的行数
            //6. 处理结果
            System.out.println(count1);
            //5. 执行sql
            int count2 = stmt.executeUpdate(sql2);//受影响的行数
            //6. 处理结果
            System.out.println(count2);
            // ============提交事务==========
            //程序运行到此处,说明没有出现任何问题,则需求提交事务
            conn.commit();
        } catch (Exception e) {
            // ============回滚事务==========
            //程序在出现异常时会执行到这个地方,此时就需要回滚事务
            conn.rollback();
            e.printStackTrace();
        }
        //7. 释放资源
        stmt.close();
        conn.close();
    }
}

运行结果:

代码分析

使用Connection的步骤

导入自己的各种信息

//1. 注册驱动
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2. 获取连接
        // String url = "jdbc:mysql://127.0.0.1:3306/books"; // 如果是mysql5这样写
        String url = "jdbc:mysql://localhost:3306/books?serverTimezone=GMT%2B8&useOldAliasMetadataBehavior=true"; // 如果是mysql8这样写
        String username = "root";
        String password = "12345";

创建Connection对象

Connection conn = DriverManager.getConnection(url, username, password);

定义sql语句

//3. 定义sql
       String sql1 = "update book set price = price - 8 where reclD = 1";
       String sql2 = "update book set price = price - 8 where reclD = 2";
       String sql3 = "update book set price = price - 8 where reclD = 3";

调用creatStatement()方法

//4. 获取执行sql的对象 Statement
        Statement stmt = conn.createStatement();

Connection的理解

这就是Connection(数据库连接对象) 的在代码中的涉及部分,那么Connection到底是什么了,就跟它的名字一样,数据库连接对象,从面相对象的角度理解,这个对象就是封装了去连接整个数据库信息的用户的各种信息,比如url,password,username,这些信息,把这些信息封装打包,成为一个Connection(数据库连接对象),然后就可以通过这个封装好的对象去进行一系列操作了。

其他信息

Connection(数据库连接对象)作用:

  • 获取执行 SQL 的对象
  • 管理事务

如果大家觉得有用的话,可以关注我下面的微信公众号,极客李华,我会在里面更新更多行业资讯,企业面试内容,编程资源,如何写出可以让大厂面试官眼前一亮的简历等内容,让大家更好学习编程,我的抖音,B站也叫极客李华。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
存储 关系型数据库 MySQL
简述MySQL数据库中九种基本对象的定义
简述MySQL数据库中九种基本对象的定义。
76 0
|
8月前
|
存储 SQL 关系型数据库
数据库对象
数据库对象
114 0
|
8天前
|
存储 Oracle 关系型数据库
Oracle的模式与模式对象:数据库的“城市规划师”
【4月更文挑战第19天】在Oracle数据库中,模式是用户对象的集合,相当于数据库的城市规划,包含表、视图、索引等模式对象。模式对象是数据存储结构,如表用于存储数据,视图提供不同查看角度,索引加速数据定位。良好的模式与模式对象设计关乎数据效率、安全和稳定性。规划时需考虑业务需求、性能、安全和可扩展性,以构建高效数据库环境,支持企业业务发展。
|
存储 传感器 数据管理
【软件设计师备考 专题 】面向对象数据库和分布式对象:理解新的数据管理概念
【软件设计师备考 专题 】面向对象数据库和分布式对象:理解新的数据管理概念
53 0
|
1月前
|
SQL 数据库 OceanBase
OceanBase数据库的回收站功能是为了短暂保存被删除的数据库对象
【2月更文挑战第21天】OceanBase数据库的回收站功能是为了短暂保存被删除的数据库对象
20 7
|
2月前
|
SQL 数据库 OceanBase
OceanBase数据库的回收站功能是为了短暂保存被删除的数据库对象
OceanBase数据库的回收站功能是为了短暂保存被删除的数据库对象
97 7
|
8月前
|
SQL 关系型数据库 MySQL
使用IntelliJ IDEA连接数据库,快速创建实体类对象,自动生成get,set,toString方法以及无参有参构造器
使用IntelliJ IDEA连接数据库,快速创建实体类对象,自动生成get,set,toString方法以及无参有参构造器
|
6月前
|
SQL 关系型数据库 数据库连接
【100天精通python】Day31:使用python操作数据库_数据库编程接口,连接对象和游标对象,数据库连接配置
【100天精通python】Day31:使用python操作数据库_数据库编程接口,连接对象和游标对象,数据库连接配置
89 0
|
6月前
|
SQL Oracle 关系型数据库
Oracle数据库对象---你diss了嘛
Oracle数据库对象---你diss了嘛
|
7月前
|
SQL 关系型数据库 MySQL
MySQL数据库对象与数据备份和还原详解(下)
MySQL数据库对象与数据备份和还原详解(下)
40 0

热门文章

最新文章