JDBC001--java中的jdbc数据库的初步连接(MySQL8.0)_java连接mysql8.0-程序员宅基地

技术标签: java  JDBC  数据库  eclipse  

目录

下载数据库MySQL8.0驱动

​编辑 将数据库驱动配置到eclipse中

 编写程序连接数据库

创建并编写配置文件

创建配置文件 

编写配置文件 

读取配置文件

加载驱动

 建立数据库连接


此篇博客的开发环境为Eclipse,数据库驱动为MySQL8,

在学习MySQL时,我们都知道数据库可以让我们的数据实现持久化,且方便管理。其实我们学习java的io流时,也是在将数据持久化到文件里面去。而我们之所以要学习数据库是因为数据放置到数据库后增删改查等操作会很方便。那么我们该怎么使用eclipse来与我们的数据库产生联系呢?首先我们需要去下载数据库驱动。

下载数据库MySQL8.0驱动

链接: https://pan.baidu.com/s/19WeaIl2h9fTInREcqmlzLQ?pwd=6666     提取码: 6666 

 百度网盘里面的资源是zip压缩包的形式,我们下载后需要将其解压后才能使用。

解压后的数据库有驱动文件如下:

 将数据库驱动配置到eclipse中

下载数据库驱动后,我们需要将data目录下的数据库驱动jar包加载到我们的eclipse中。首先,我们先右击我们的项目名,然后向下找到“Build  Path”,接着找到“Configure  Build  Path”,之后我们去选择页面中的“Libraries”,再去点击右边框的“Add  External JARs....”(添加外部的库)

 导入成功后我们可以看到在“Referenced  Libraries”目录下有着我们MySQL的驱动jar包

 MySQL驱动导入成功了,接下来我们去编写相应的程序来连接我们的数据库。

 编写程序连接数据库

一般在实际的开发使用中我们的数据库连接需要使用到配置文件,即.properties。配置文件的使用可以方便我们后期查看与修改我们的数据库连接对象

创建并编写配置文件

创建配置文件 

我们的配置文件一般写在项目的src目录下,先鼠标右击“src”目录,然后选择“New”再去点击“file”(或者是点击“src”之后使用快捷键ctr+n,之后输入file),之后将文件名命名为jdbc.properties

编写配置文件 

接着我们就可以在配置文件中写入我们的之后要用的信息,我们都知道在配置文件中的数据都是以键值对的形式存在的,因此我们的数据可以使用“键=值”形式,如下我们将需要用到的数据库用户名,数据库密码,想要连接的数据库及加载的jdbc驱动类。

user=数据库用户名
password=数据库密码
url=jdbc:mysql://localhost:数据库端口号/数据库名
driverClass=com.mysql.cj.jdbc.Driver
#数据库为MySQL8.0

 这里我们需要注意的是如果使用的MySQL版本是5.0的话,数据库驱动类的那里就不需要多“cj”这个字符串。可以写成如下形式:

【需要注意的是,MySQL5是不支持中文的数据写入数据库中的,如果对MySQL5的data目录下的my.ini文件进行修改的话,后期想要写入中文的字符时,需要在我们的url地址的数据库后面加上

?characterEncoding=utf8”】 ,如下:

如果不知道怎么去修改my.ini文件里面的字符编码的话可以参考这篇文章:

 Day001--MySQL中的下载与安装及环境变量的配置_码到成龚的博客-程序员宅基地

 就会看到具体的修改了:

 现在,我们的配置文件编写好了,接下来我们就去创建一个类来编写代码来加载配置文件,加载驱动并连接我们的数据库

读取配置文件

我们可以使用Properties对象的load方法来加载我们的文件进来,当然事先要先将文件读取到才行。我们的代码可以如下编写来将配置文件读取到:InputStream(字节输入流对象) is=当前创建的类名.Class.getClassLoader().getResourceAsStream("配置文件的名字.properties");

  接下来我们读取出来配置文件里面的键,并将值赋值给相应的变量,存储下来后期使用。我们再加载配置文件时,需要进行抛异常处理

为了后期的方便,可以将我们抛出的的异常范围扩大,直接抛Exception 即可

 接下来我们读取里面的键信息,可以使用Properties对象里面的getProperty方法

 数据读取成功了,接下来我们去使用反射的方法来加载驱动Class.forName();

加载驱动

 建立数据库连接

 现在万事俱备,我们离数据连接只差建立连接了。接下来我们需要使用使用Connection类及DriverManager类来建立连接对象。并且需要传入连接的数据库地址,数据库用户名,数据库密码三个参数 

接着我们去打印,控制台如果输出的是对象地址的话代表我们的连接是成功的: 

代码及效果:

import java.util.Properties;
import java.io.*;
import java.sql.*;
public class JDBC1 {
	public static void main(String[] args) throws Exception {
		//找到配置文件位置
		InputStream is=JDBC1.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");
		//加载驱动
		Class.forName(driverClass);  
		//建立连接
		Connection conn=DriverManager.getConnection(url,user,password);  
		System.out.println(conn);
		
	}
}

如上表示我们的数据库连接是成功的,如果想要继续了解与学习,请点击如下链接:

JDBC002--java中连接数据库后执行insert插入记录的操作_码到成龚的博客-程序员宅基地_java执行insert 如果有问题请在评论区留言。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_53046747/article/details/126111272

智能推荐

c# 调用c++ lib静态库_c#调用lib-程序员宅基地

文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib

deepin/ubuntu安装苹方字体-程序员宅基地

文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang

html表单常见操作汇总_html表单的处理程序有那些-程序员宅基地

文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些

PHP设置谷歌验证器(Google Authenticator)实现操作二步验证_php otp 验证器-程序员宅基地

文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器

【Python】matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距-程序员宅基地

文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距

docker — 容器存储_docker 保存容器-程序员宅基地

文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器

随便推点

网络拓扑结构_网络拓扑csdn-程序员宅基地

文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn

JS重写Date函数,兼容IOS系统_date.prototype 将所有 ios-程序员宅基地

文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios

如何将EXCEL表导入plsql数据库中-程序员宅基地

文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql

Git常用命令速查手册-程序员宅基地

文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...

分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120-程序员宅基地

文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120

【C++缺省函数】 空类默认产生的6个类成员函数_空类默认产生哪些类成员函数-程序员宅基地

文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数

推荐文章

热门文章

相关标签