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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 进行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);
        }
    }
    `
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
11月前
|
Java 数据库连接 数据库
【YashanDB知识库】WAS配置YashanDB JDBC连接
【YashanDB知识库】WAS配置YashanDB JDBC连接
|
11月前
|
Oracle Java 关系型数据库
【YashanDB知识库】如何配置jdbc驱动使getDatabaseProductName()返回Oracle
【YashanDB知识库】如何配置jdbc驱动使getDatabaseProductName()返回Oracle
|
安全 Java 数据库连接
gbase8a JDBC常用特性-Kerberos认证方式连接
JDBC常用特性-Kerberos认证方式连接
|
Java 数据库连接 网络安全
JDBC常用特性-SSH隧道连接
JDBC常用特性-SSH隧道连接
|
Java 数据库连接
JDBC连接复习
JDBC连接复习
174 1
|
存储 Java 数据库连接
南大通用 GBase 8s JDBC字符集参数详解
本文详细介绍了南大通用GBase 8s V8.8 数据中四个关键的JDBC字符集参数:CLIENT_LOCALE、DB_LOCALE、NEWCODESET和NEWLOCALE,涵盖它们的功能、配置方法及其在数据库操作中的作用,旨在帮助开发者和数据库管理员提升数据处理的效率与准确性。
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
145 7
|
SQL druid Java
JDBC和数据库连接池-两个工具类-JDBCUtilsByDruid和BasicDAO
JDBC和数据库连接池-两个工具类-JDBCUtilsByDruid和BasicDAO
595 0
|
Java 关系型数据库 MySQL
mysql5.7 jdbc驱动
遵循上述步骤,即可在Java项目中高效地集成MySQL 5.7 JDBC驱动,实现数据库的访问与管理。
2831 1
|
SQL druid Java
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(下)
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)
222 3
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(下)

热门文章

最新文章