这篇文章跟读者们介绍Java语言如何连接到MySQL数据库相关操作,及FAQ(Frequently Asked Questions)介绍。

选择工具和准备数据集

IDE:Eclipse

数据库:使用的是MySQL 8.0

驱动程序包:mysql-connector-java-8.0.12.jar

驱动程序类名:com.mysql.cj.jdbc.Driver

提前准备工作:笔者使用MySQL Workbench 工具来进行数据库CRUD各种操作,在数据库中建立了一个test数据库,接着在test数据库中建立teacher表格和往向表格中增加数据。

并且已经往表中插入了6项数据。

在Eclipse中建立一个数据库操作的Java project。并且在project里面引入(配置)驱动程序jar包

主要步骤

1.导入所需要的包

2.注册JDBC驱动

3.建立连接到数据库

4.执行 CRUD 操作

5.处理得到的结果

6.关闭资源,释放连接

提供源代码参考:

 //STEP 1:导入包
//大多数情况下,使用import java.sql.*;就足够了。
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class DBConnettion { //不同版本的数据库驱动,名字会不相同同。
//数据库驱动 mysql-connector-java 6.0以上的版本, 驱动名是:"com.mysql.cj.jdbc.Driver"
//旧版本驱动名是:"com.mysql.jdbc.Driver"
private static final String JDBC_DEIVER = "com.mysql.cj.jdbc.Driver";
//笔者查看本机数据库进程,默认使用3306端口,大家根据自己数据库进程端口号来相应修改。
//比如我要访问MySQL的test数据库, 主机ip:端口号/数据库名称 数据库URL格式:---"jdbc:mysql://localhost:3306/test
private static final String DB_URL = "jdbc:mysql://localhost:3306/test?useSSL=false";//?useUnicode=true&characterEncoding=utf8&useSSL=false
private static final String USER = "****"; //"****"替换成自己的数据库用户名
private static final String PASS = "****"; //"****"替换成自己的数据库密码 public static void main(String[] args) {
Connection conn = null;
Statement stmt = null; try {
//STEP 2:注册 JDBC 驱动
Class.forName(JDBC_DEIVER); //STEP 3:建立连接到数据库
System.out.println("正在连接数据库......");
conn = DriverManager.getConnection(DB_URL, USER, PASS);
stmt = conn.createStatement(); //STEP 4:执行 CRUD 操作
System.out.println("正在查询数据:");
String sql = "select * from teacher;";
ResultSet rs = stmt.executeQuery(sql); //STEP 5:处理得到结果
System.out.println("Department ID Name");
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
if (!rs.isLast())
System.out.println("\t " + id + " " + name);
else
System.out.println( " " + id + " " + name);
} //STEP 6:关闭资源,释放连接。
rs.close();
stmt.close();
conn.close();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally {
try {
if (stmt != null)
stmt.close();
if (conn != null)
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
System.out.println("释放数据库连接......");
}
}

运行结果:

常见问题解析及解决方法

出现问题:

java.sql.SQLException: The server time zone value '???ú±ê×??±??' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

解析:

从错误提示可知道是时区的错误,因此只要将数据库系统的时区设置为你当前系统时区即可。

解决方法:

因此使用root用户登录mysql,按照如下图所示操作即可。

查看数MySQL据库系统的时区设置

show variables like '%time_zone%';

笔者电脑系统时区设置为GMT+8:北京时间。而数据库系统时区默认为GMT+0(格林尼治时间),因此修改数据库系统时区跟我的系统时区相互一致。

set global time_zone = '+8:00';

对数据库系统时区变量做修改,不会立即发生改变。退出本次黑窗命令行(客户端)后

重新登录数据库,再次进行数据库系统时区查询,发现已经做出更改。

show variables like '%time_zone%';

出现问题:

Sat May 04 19:01:08 CST 2019 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.

解析:

从MySQL数据库 5.5.45+ 以后,对数据库的访问都要求建立SSL加密连接。我们只是做一个简单的数据库访问实例,因此访问数据库不进行SSL加密连接。

解决方法:

可以在数据库URL连接语句末尾加上"?useSSL=false"来取消数据库的警告。

或者可以给数据库服务器提供证书验证的信任库,进行SSL加密连接。

Java连接MySQL简单步骤及常见问题解析的更多相关文章

  1. 【JDBC】java连接MySQL数据库步骤

    java连接数据库步骤 1. 加载驱动 Class.forName("com.mysql.java.Driver"); 或: registerDriver(new com.mysq ...

  2. java连接mysql数据库详细步骤解析

    java连接mysql数据库详细步骤解析      第一步:下载一个JDBC驱动包,例如我用的是:mysql-connector-java-5.1.17-bin.jar      第二步:导入下载的J ...

  3. JAVA使用jdbc连接MYSQL简单示例

    以下展示的为JAVA使用jdbc连接MYSQL简单示例: import java.sql.DriverManager; import java.sql.ResultSet; import java.s ...

  4. Java连接MySQL数据库及简单操作代码

    1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...

  5. JDBC连接(MySql)数据库步骤,以及查询、插入、删除、更新等十一个处理数据库信息的功能

    主要内容:  JDBC连接数据库步骤. 一个简单详细的查询数据的例子. 封装连接数据库,释放数据库连接方法. 实现查询,插入,删除,更新等十一个处理数据库信息的功能.(包括事务处理,批量更新等) 把十 ...

  6. 【JDBC】Java 连接 MySQL 基本过程以及封装数据库工具类

    一. 常用的JDBC API 1. DriverManager类 : 数据库管理类,用于管理一组JDBC驱动程序的基本服务.应用程序和数据库之间可以通过此类建立连接.常用的静态方法如下 static ...

  7. Java进阶(二十五)Java连接mysql数据库(底层实现)

    Java进阶(二十五)Java连接mysql数据库(底层实现) 前言 很长时间没有系统的使用java做项目了.现在需要使用java完成一个实验,其中涉及到java连接数据库.让自己来写,记忆中已无从搜 ...

  8. java连接mysql

    Java 连接 MySQL 需要驱动包,最新版下载地址为:http://dev.mysql.com/downloads/connector/j/,解压后得到jar库文件,然后在对应的项目中导入该库文件 ...

  9. 转载:Java连接MySQL 数据库的正确操作流程

    转载网址:http://www.bitscn.com/pdb/mysql/201005/186551.html       以下的文章主要介绍的是Java连接MySQL 数据库(以MySQL数据库为例 ...

随机推荐

  1. rpm -qa|grep nfs >/dev/null 2>&1作用

    在使用一些shell命令是,经常会用到rpm -qa|grep nfs >/dev/null 2>&1之类的命令,该命令干嘛用的呢? 其实这个命令就是将rpm -qa|grep n ...

  2. Jquery toastr提示框

    toastr是一个基于JQuery的消息提示插件; 1. 下载toastr和jquery https://jquery.com/download/ https://codeseven.github.i ...

  3. wordpress新注册用户或重置密码链接失效

    在网上找了好多个博客,一个比一个不要脸,要更改的是两个文件,最后都抄成一个文件了. 原文链接https://www.cnblogs.com/liudecai/p/6474611.html 我是按照这个 ...

  4. 1 Processing入门简介

    1 Processing入门简介 1.1 Before you start Processing是一个为开发面向图形的应用(visually oriented application)而生的简单易用的 ...

  5. Docker实战笔记命令篇

    拉取一个镜像 docker pull ubuntu:14.04 查看系统中的镜像 docker images 运行镜像并进入 docker run -it ubuntu:14.04 查看运行的容器 d ...

  6. ELK 学习笔记之 elasticsearch 版本控制

    版本控制: elasticsearch 版本控制: 内部版本控制 外部版本控制 内部版本控制: 内部版本会检查你提供的版本值和文档的版本值是否一致,如果不一致就报错,一致则可以更新. curl -XP ...

  7. (转) websocket 和 socket 剖析

    Socket 与 WebSocket 本站文章除注明转载外,均为本站原创或者翻译. 本站文章欢迎各种形式的转载,但请18岁以上的转载者注明文章出处,尊重我的劳动,也尊重你的智商: 本站部分原创和翻译文 ...

  8. .NET进阶篇-语言章-2-Delegate委托、Event事件

    知识只有经过整理才能形成技能 整个章节分布简介请查看第一篇 内容目录 一.概述 二.解析委托知识点 1.委托本质 2.委托的使用 3.委托意义 逻辑解耦,减少重复代码 代码封装支持扩展 匿名方法和La ...

  9. 各种xml配置文件(所含内部标签及顺序)的提示功能是真的人性化

    通过mybatis generator的配置文件来举例,其他配置文件(web.xml,mybatis,spring,springmvc等)同理 mybatis可以通过mybatis generator ...

  10. centos7版本以上root密码破解

    centos7版本以上root密码破解 主讲内容: 1.centos7版本以上root密码破解   一.centos7版本以上root密码破解 重启服务器,按键盘的方向键(上 下) 按e 进入紧急救援 ...