IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> jdbc:数据库的连接方式 -> 正文阅读

[大数据]jdbc:数据库的连接方式

数据库的连接方式

数据库连接的四个要素

1、加载驱动Driver:加载 JDBC 驱动需调用 Class 类的静态方法 forName(),向其传递要加载的 JDBC 驱动的类名
2、统一资源定位符url:JDBC URL 用于标识一个被注册的驱动程序,驱动程序管理器通过这个 URL 选择正确的驱动程序,从而建立到数据库的连接。mysql的统一资源定位符为:jdbc:mysql://localhost:3306/数据库名
3、用户名:mysql的用户名一般为root
4、密码
四个基本要素可以写在jdbc.properties中,使用类的加载器加载读取,可提高代码的可移植性,解耦。
可以调用 DriverManager 类的 getConnection() 方法建立到数据库的连接

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
import org.junit.Test;


public class ConnectionTest {
    //方式一:Driver接口实现类,支持多数据库管理
    @Test
    public void testConnectionTest1() throws SQLException {
        //目的:获取connection对象,使用Driver

        Driver driver = new com.mysql.jdbc.Driver();//实例化需要mysql具体的Driver的实现类
        /*
        需要将mysql的驱动加载进来:
        在当前工程下右键新建一个Folder,命名为lib,导入驱动mysql-connection-java-版本号-bin-jar
        将驱动的jar包放入lib文件夹中,右键选择Build Path
         */
//        String url = "jdbc:mysql://localhost:3306/bookmanager";//若没有指定字符集报错,需要使用下面操作
//        String url = "jdbc:mysql://localhost:3306/bookmanager?characterEncoding=latin1&useConfigs=maxPerformance";
        String url = "jdbc:mysql://localhost:3306/bookmanager?characterEncoding=utf-8";
        /*
        URL:统一资源定位符
        在jdbc中这是固定操作
        String url = "jdbc:mysql://localhost:3306/数据库名";
        jdbc:mysql   协议
        localhost    ip地址
        3306         mysql默认的端口号

        ?characterEncoding=字符集   指定字符集
         */
        Properties info = new Properties();
        info.setProperty("user","root");
        info.setProperty("password","124869");
        /*
        将用户名和密码封装在Properties中,Properties存储的是键值对
        Properties info = new Properties();

        info.setProperty("user","root");//mysql的用户名
        info.setProperty("password","123456");//mysql密码
         */
        Connection conn = driver.connect(url, info);

        System.out.println(conn);
    }




    //方式二:对方法1的迭代:使用反射将第三方的API包装起来,增加了代码的可移植性
    @Test
    public void testConnection2() throws Exception {
        //1、获取Driver的实现类对象
        Class class1 = Class.forName("com.mysql.jdbc.Driver");//使用反射
        Driver driver =(Driver) class1.newInstance();//new空参构造器

        //2、提供要链接的数据库
        String url = "jdbc:mysql://localhost:3306/bookmanager?characterEncoding=utf-8";

        //3、提供连接需要的用户名、密码
        Properties info = new Properties();
        info.setProperty("user","root");
        info.setProperty("password","124869");

        //4、获取连接
        Connection conn = driver.connect(url, info);

        System.out.println(conn);
    }




    //方式三:使用DriverManager替换Driver
    @Test
    public void testConnection3() throws Exception {

        //1、提供另外三个获取连接的基本信息
        String url = "jdbc:mysql://localhost:3306/bookmanager?characterEncoding=utf-8";
        String user = "root";
        String password = "124869";

        //2、获取Driver的实现类对象
        Class class1 = Class.forName("com.mysql.jdbc.Driver");
        Driver driver = (Driver)class1.newInstance();

        //注册驱动
        DriverManager.registerDriver(driver);

        //获取连接
        Connection connection = DriverManager.getConnection(url, user, password);

        System.out.println(connection);
    }




    //方式四:可以只是加载驱动,不用显示的注册驱动
    @Test
    public void testConnection4() throws Exception {
        //1、提供另外三个获取连接的基本信息
        String url = "jdbc:mysql://localhost:3306/bookmanager?characterEncoding=utf-8";
        String user = "root";
        String password = "124869";

        //2、获取Driver的实现类对象
        Class class1 = Class.forName("com.mysql.jdbc.Driver");//mysql可以省略,但一般不省略。
        //相较于方式三可以省略如下操作,在mysql的实现类中,声明了如下操作
            /*
                static {
                        try {
                            DriverManager.registerDriver(new Driver());
                        } catch (SQLException var1) {
                            throw new RuntimeException("Can't register driver!");
                        }
                    }
             */
//        Driver driver = (Driver)class1.newInstance();
//        //注册驱动
//        DriverManager.registerDriver(driver);

        //获取连接
        Connection connection = DriverManager.getConnection(url, user, password);

        System.out.println(connection);
    }





    //方式五(final版):将数据库连接所需要的4个基本配置信息声明在配置文件当中,通过读取配置文件的方式,获取连接
    
    /*好处:
        实现数据与代码的分离,实现了解耦
        如果需要修改配置信息,可以避免程序重新打包
     */
    
    @Test
    public void testConnection5() throws Exception {
        /*
        	1、在src下新建file,命名为jdbc.properties
       		2、在jdbc.properties中填写配置信息
         */

        //1、读取配置文件中的4个基本信息
        InputStream is = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
        //获取类的加载器(系统加载器),并使用加载器读取配置文件,默认识别路径是在src下
        //ConnectionTest.class.getClassLoader()   获取当前类的加载器
        //getResourceAsStream("jdbc.properties")   调用方法读取文件信息
        Properties pros = new Properties();
        pros.load(is);
        String user = pros.getProperty("user");
        String password = pros.getProperty("password");
        String url = pros.getProperty("url");
        String driverClass = pros.getProperty("driverClass");

        //2、加载驱动
        Class.forName(driverClass);

        //3、获取连接
        Connection conn = DriverManager.getConnection(url, user, password);

        System.out.println(conn);
    }
}
//一般采用方式五的方法进行数据库连接

在这里插入图片描述

下面描述的getResourceAsStream的用法和解释

https://www.cnblogs.com/macwhirr/p/8116583.html

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-17 22:14:33  更:2022-03-17 22:16:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 17:46:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码