连接数据库的方式

好买-葡萄
• 阅读 730

好买网 www.goodmai.com IT技术交易平台 将JAVA程序连接至数据库 1.下载 mysql 驱动 jar 包 2.添加入JAVA程序文件中 3.添加到 library 库中 连接数据库的方式

连接数据库的方式

获取数据库的五种方式 mysqL驱动5.1.6可以无需CLass . forName(“com.mysql.jdbc.Driver”); 从jdk1.5以后使用了jdbc4,不再需要显示调用class.forName()注册驱动而是自动调用驱动jar包下META-INF\services\java .sql.Driver文本中的类名称去注册 建议还是写上 CLass . forName(“com.mysql.jdbc.Driver”),更加明确

package com.ftn.jdbc.myjdbc;

//数据库的不同连接方式
import com.mysql.cj.jdbc.Driver;
import org.junit.jupiter.api.Test;

import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;

public class JdbcConn {
    public static void main(String[] args) {
    }

    //方式一
    //直接加载Driver对象,获取连接
    @Test
    public void connect01() throws SQLException {
        Driver driver = new Driver();
        Properties properties = new Properties();
        properties.setProperty("user","root");
        properties.setProperty("password","122800");
        Connection connect = driver.connect("jdbc:mysql://localhost:3306/db_03", properties);
        System.out.println("第三种连接方式:" + connect);
        connect.close();
    }

    //方式二
    //使用反射加载 Driver 类,动态加载,更加灵活,减少依赖性
    @Test
    public void connect02() throws Exception {
        Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
        Driver driver =(Driver) aClass.newInstance();

        //创建 url,user和 password
        Properties properties = new Properties();
        properties.setProperty("user","root");
        properties.setProperty("password","122800");
        Connection connect = driver.connect("jdbc:mysql://localhost:3306/db_03", properties);
        System.out.println("第三种连接方式:" + connect);
        connect.close();
    }

    //方式三
    //使用DriverManager代替Driver进行统一管理
    @Test
    public void connect03() throws Exception {
        //使用反射加载 Driver
        Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
        Driver driver = (Driver) aClass.newInstance();

        //创建 url,user和 password
        String url = "jdbc:mysql://localhost:3306/db_03";
        String user = "root";
        String password = "122800";

        DriverManager.registerDriver(driver);   //注册 Driver 驱动
        Connection connection = DriverManager.getConnection(url, user, password);
        System.out.println("第三种连接方式:" + connection);
        connection.close();
    }

    //方式四
    //使用 Class.forName 自动完成注册驱动,简化代码
    /*
    1. mysqL驱动 5.1.6可以无需 CLass . forName("com.mysql.jdbc.Driver");
    2. 从jdk1.5以后使用了jdbc4,不再需要显示调用class.forName()注册驱动而是自动调用驱动
    jar包下 META-INF\services\java .sql.Driver文本中的类名称去注册
    3. 建议还是写上CLass . forName("com.mysql.jdbc.Driver"), 更加明确
    */
    @Test
    public void connect04() throws Exception {
        //使用反射加载 Driver
        /*
        Driver 类源码中的静态代码块
        1. 在类加载时,会执行 DriverManager.registerDriver(new Driver());
        2. 即 Driver 会自动注册
        static {
                try {
                DriverManager.registerDriver(new Driver());
                } catch (SQLException var1) {
                throw new RuntimeException("Can't register driver!");
            }
        }
         */

        Class<?> aClass = Class.forName("com.mysql.cj.jdbc.Driver");
        //创建 url,user和 password
        String url = "jdbc:mysql://localhost:3306/db_03";
        String user = "root";
        String password = "122800";

        Connection connection = DriverManager.getConnection(url, user, password);
        System.out.println("第四种方式:" + connection);
        connection.close();
    }

    //方式五
    //在方式四基础上改进,增加配置文件,让连接 mysql 更加灵活
    @Test
    public void connect05() throws Exception {
        //通过 Properties 对象获取配置文件的信息
        Properties properties = new Properties();
        properties.load(new FileInputStream("src\\mysql.properties"));

        //获取相关的值
        String url = properties.getProperty("url");
        String user = properties.getProperty("user");
        String password = properties.getProperty("password");
        String driver = properties.getProperty("driver");

        Class<?> aClass = Class.forName(driver);

        Connection connection = DriverManager.getConnection(url, user, password);
        System.out.println("第五种方式:" + connection);
        connection.close();
    }
}
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
Java日期时间API系列31
  时间戳是指格林威治时间1970年01月01日00时00分00秒起至现在的总毫秒数,是所有时间的基础,其他时间可以通过时间戳转换得到。Java中本来已经有相关获取时间戳的方法,Java8后增加新的类Instant等专用于处理时间戳问题。 1获取时间戳的方法和性能对比1.1获取时间戳方法Java8以前
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这