JDBC(四) 连接参数的配置(附DBUtil工具类)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 进行JDBC操作时,连接参数的配置(附DBUtil工具类)

JDBC连接时,两种常见的地址书写

1、jdbc连接oracle数据库

driver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
username=chy
password=123
可能会改变的值
1、本机地址、mysql端口号
2.3、登陆oracle用户名与密码

在这里插入图片描述

2、jdbc连接mysql数据库

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/project
username=root
password=root
可能会改变的值
1、本机地址、oracle的端口号
2、mysql的数据库名
3、登陆mysql用户名与密码

在这里插入图片描述
在这里插入图片描述

工具类DBUtil

作用是可以让我们可以在配置文件中修改配置参数,而无需在相关的java类中进行操作
并且可以直接调用本类,进行数据库连接、执行sql语句,关闭相关变量的操作
oracle与mysql通用
    import java.io.IOException;
    import java.io.InputStream;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.Properties;
    
    public class DBUtil {
        static String driver;
        static String url;
        static String user;
        static String password;
        
        //读取属性文件properties并获取内容
        static{
            //准备一个空的map,没有key-value
            Properties prop = new Properties();
            
            //读取文件,并将文件键值对存入Properties对象
            //InputStream is = new FileInputStream(new File("C:\Users\Administrator\workspace\java_empmgr2\src\conn.properties"));
            InputStream is = DBUtil.class.getResourceAsStream("/jdbc.properties"); //classpath
            try {
                prop.load(is);
            } catch (IOException e) {
                e.printStackTrace();
            }
            //从prop中根据key获取四个参数的值
            driver = prop.getProperty("driver");
            //driver = prop.get("driver");
            url = prop.getProperty("url");
            user = prop.getProperty("username");
            password = prop.getProperty("password");
            
            //加载驱动
            try {
                Class.forName(driver);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
        
        /**
         * 获取数据库连接
         * @return
         */
        public static  Connection getConnection(){
            Connection conn = null;
            try{            
                //建立数据库连接            
                conn = DriverManager.getConnection(url, user, password);
            }catch(SQLException e){
                e.printStackTrace();
            }
            return conn;
            
        }
        
        /**
         * 关闭数据库资源
         * @param rs
         * @param stmt
         * @param conn
         */
        public static void closeAll(ResultSet rs ,Statement stmt,Connection conn){
            //关闭数据库资源
            try {
                if(rs!=null){
                    rs.close();
                }                
            } catch (SQLException e) {
                e.printStackTrace();
            }
            
            try {
                if(stmt != null){
                    stmt.close();
                }                
            } catch (SQLException e) {
                e.printStackTrace();
            }
            
            try {
                if(conn != null){
                    conn.close();
                }
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        
        /**
         * DML:insert  update  delete
         */
        public static int executeUpdate(String  sql,Object ... params) {
            Connection conn =  null;
            PreparedStatement pstmt = null;
            int n = 0;
            try{
                //获取数据库连接
                conn = DBUtil.getConnection();
                
                //使用手枪发送SQL命令并得到结果            
                pstmt = conn.prepareStatement(sql);
                
                for(int i=0;i<params.length;i++){
                    pstmt.setObject(i+1, params[i]);
                }        
                n = pstmt.executeUpdate();
                
                
            }catch(SQLException e){
                e.printStackTrace();
            }finally{
                //关闭数据库资源
                DBUtil.closeAll(null, pstmt, conn);
            }
                    
            //返回数据
            return n;
        }
        public static void main(String[] args) {
            Connection conn = getConnection();
            System.out.println(conn);
        }
    }
    `
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
安全 Java 数据库连接
gbase8a JDBC常用特性-Kerberos认证方式连接
JDBC常用特性-Kerberos认证方式连接
|
1月前
|
Java 数据库连接 网络安全
JDBC常用特性-SSH隧道连接
JDBC常用特性-SSH隧道连接
|
5月前
|
Java 数据库连接
JDBC连接复习
JDBC连接复习
58 1
|
2月前
|
存储 Java 数据库连接
南大通用 GBase 8s JDBC字符集参数详解
本文详细介绍了南大通用GBase 8s V8.8 数据中四个关键的JDBC字符集参数:CLIENT_LOCALE、DB_LOCALE、NEWCODESET和NEWLOCALE,涵盖它们的功能、配置方法及其在数据库操作中的作用,旨在帮助开发者和数据库管理员提升数据处理的效率与准确性。
|
3月前
|
SQL druid Java
JDBC和数据库连接池-两个工具类-JDBCUtilsByDruid和BasicDAO
JDBC和数据库连接池-两个工具类-JDBCUtilsByDruid和BasicDAO
181 0
|
5月前
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
61 7
|
5月前
|
SQL Java 数据库连接
JDBC连接SQL Server2008 完成增加、删除、查询、修改等基本信息基本格式及示例代码
这篇文章提供了使用JDBC连接SQL Server 2008数据库进行增加、删除、查询和修改操作的基本步骤和示例代码。
|
5月前
|
SQL 存储 Java
完整java开发中JDBC连接数据库代码和步骤
该博客文章详细介绍了使用JDBC连接数据库的完整步骤,包括加载JDBC驱动、提供连接URL、创建数据库连接、执行SQL语句、处理结果以及关闭JDBC对象的过程,并提供了相应的示例代码。
|
3月前
|
Java 关系型数据库 MySQL
mysql5.7 jdbc驱动
遵循上述步骤,即可在Java项目中高效地集成MySQL 5.7 JDBC驱动,实现数据库的访问与管理。
736 1
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
155 0