开始做课程设计的时候根本无从下手,后来查阅资料后发现是先从数据库开始的。整个课程设计需要用到的如下图,今天总结一下数据库接口!



数据库接口需要用到两个类,一个是DAO.java,另一个是properties.java。

1、properties.java文件

因为使用 JDBC 操作数据库,基本流程是相同的,只是操作的内容不同,因此,可将数据库的连接和有关操作封装成类,后续操作数据库时只要调用相关类的方法即可。

步骤

(1)先创建一个以properties 为后缀的文件,比如my.properties ,双击打开,然后在文件写入数据库的相关信息,如下:



(2)将数据库驱动程序、 UTL、用户名、密码等写入到数据库配置文件(即properties 文件, 它是一种特殊类型的 Map 结构,关键字与值都是字符串, 中间用“=”连接,既可以用文件保存,也可以从文件中装入)中;

(3)properties.java这个文件中的properties类专门读取配置文件中参数:用 static块加载配置文件,且提供 static 方法 String getValue(String key);

package hr.dao;
import java.io.FileInputStream;
import java.util.Properties; public class properties {
private static Properties p = null;
static {
try {
p = new Properties();
p.load(new FileInputStream("mysql.properties"));// 加载配置文件
} catch (Exception e) {
e.printStackTrace();
}
} // 获取键对应的值
public static String getValue(String key) {
return p.get(key).toString();
}
}

创建一个properties类的对象,调用load()方法加载配置文件,通过一个文件输入字节流来获取文件内容,getValue()方法就是方便DAO类获取文件中的内容,以达到封装的效果。

package hr.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import javax.swing.JOptionPane; /**
* 数据库接口类
*
* @author DELL
*
*/
public class DAO { private static DAO dao = new DAO(); // 声明DAO类的静态实例 /**
* 利用静态模块加载数据库驱动
*/
static {
try {
String driver=properties.getValue("driver");
Class.forName(driver); // 加载数据库驱动
} catch (ClassNotFoundException e) {
JOptionPane.showMessageDialog(null, "数据库驱动加载失败,请将驱动包配置到构建路径中。\n" + e.getMessage());
e.printStackTrace();
}
} /**
* 获得数据库连接的方法
*
* @return Connection
*/
public static Connection getConnection() {//一定要声明为静态的方法
try {
Connection conn = null; // 定义数据库连接
String url = properties.getValue("url"); // 数据库admin_class
String username = properties.getValue("user"); // 数据库的用户名
String password = properties.getValue("pwd"); // 数据库密码
conn = DriverManager.getConnection(url, username, password); // 建立连接
return conn; // 返回连接
} catch (Exception e) {
JOptionPane.showMessageDialog(null, "数据库连接失败。请检查数据库用户名和密码是否正确。" + e.getMessage());
return null;
}
} public static void main(String[] args) {
System.out.println(getConnection());//后台打印可以检测是否连接成功
} }

同样DAO类把连接数据库类的操作也封装了起来,如果程序中哪里需要连接数据库直接调用DAO的getgetConnection()方法即可。需要注意:getConnection()方法已经声明为静态(全局)方法,如果不声明为static,则其他类无法调用这个方法!

附上一个课程设计的视频!哈哈,也可以关注我公众号【物联网技术猿】

[video(video-geynaYB2-1576209828594)(type-bilibili)(url-https://player.bilibili.com/player.html?aid=79055224)(image-https://ss.csdn.net/p?http://i2.hdslb.com/bfs/archive/bf4a42da69f85e7830417705b1083d4a7c0a71dd.jpg)(title-java se 课程设计)]

Java se课程设计详解——数据库接口类(1)的更多相关文章

  1. C++课程设计详解-12306的模拟实现

    目录 设计思路... 3 思路分析:.... 3 数据组织:.... 4 具体功能实现过程... 4 管理端具体功能实现:.... 4 用户端具体功能实现:.... 5 调试截图和调试过程中遇到的问题 ...

  2. 《JAVA高并发编程详解》-类的加载过程简介

  3. Java生鲜电商平台-Java后端生成Token架构与设计详解

    Java生鲜电商平台-Java后端生成Token架构与设计详解 目的:Java开源生鲜电商平台-Java后端生成Token目的是为了用于校验客户端,防止重复提交. 技术选型:用开源的JWT架构. 1. ...

  4. java反射机制深入详解

    java反射机制深入详解  转自:http://www.cnblogs.com/hxsyl/archive/2013/03/23/2977593.html 一.概念 反射就是把Java的各种成分映射成 ...

  5. java web.xml配置详解(转)

    源出处:java web.xml配置详解 1.常规配置:每一个站的WEB-INF下都有一个web.xml的设定文件,它提供了我们站台的配置设定. web.xml定义: .站台的名称和说明 .针对环境参 ...

  6. java.util.Scanner应用详解++扫描控制台输入

    java.util.Scanner应用详解   java.util.Scanner是Java5的新特征,主要功能是简化文本扫描.这个类最实用的地方表现在获取控制台输入,其他的功能都很鸡肋,尽管Java ...

  7. (转)java.util.Scanner应用详解

    java.util.Scanner应用详解   java.util.Scanner是Java5的新特征,主要功能是简化文本扫描.这个类最实用的地方表现在获取控制台输入,其他的功能都很鸡肋,尽管Java ...

  8. java并发编程 | 锁详解:AQS,Lock,ReentrantLock,ReentrantReadWriteLock

    原文:java并发编程 | 锁详解:AQS,Lock,ReentrantLock,ReentrantReadWriteLock 锁 锁是用来控制多个线程访问共享资源的方式,java中可以使用synch ...

  9. java ssl https 连接详解 生成证书 tomcat keystone

    java ssl https 连接详解 生成证书 我们先来了解一下什么理HTTPS 1. HTTPS概念 1)简介 HTTPS(全称:Hypertext Transfer Protocol over ...

随机推荐

  1. 1-9 Python判断结构

      判断结构¶ In [3]: tang=100 if tang>200: print('OK') print('test')##有缩进就不在就不在if条件结构中   test In [6]: ...

  2. Shel脚本-初步入门之《04》

    Shel脚本-初步入门-04 脚本语言的种类 4.脚本语言的种类 4.1 Shell 脚本语言的种类 Shell 脚本语言是弱类型语言(无须定义变量的类型即可使用),在 Unix/Linux 中主要有 ...

  3. 爬虫---Beautiful Soup 爬取图片

    上一篇简单的介绍Beautiful Soup 的基本用法,这一篇写下如何爬取网站上的图片,并保存下来 爬取图片 1.找到一个福利网站:http://www.xiaohuar.com/list-1-1. ...

  4. UE4 C++中出现的让人手足无措的问题(持续更新)

    最近开始涉入UE4更深层的一面——UE4 C++,由于其中的体系和在课本或者是网课上那么说的C++体系有一些误差(准确说就是遵循的C++标准不同),导致学习与运用起来有些吃力,所以作此总结,为自己的开 ...

  5. 第15节_BLE协议GATT层

    学习资料:官方手册 Vol 3: Core System Package [Host volume] Part G: Generic Attribute Profile (GATT) 这篇文章格式比较 ...

  6. python批量修改文件名(以修改图片名为例)

    #coding=utf-8import sys, string, os, shutil #输入目录名和前缀名,重命名后的名称结构类似prefix_0001 def RenameFiles(srcdir ...

  7. 16-numpy笔记-莫烦pandas-4

    代码 import pandas as pd import numpy as np dates = pd.date_range('20130101', periods=6) df=pd.DataFra ...

  8. python27期day14:有参装饰器、多个装饰器装饰一个函数、递归、作业题

    1.有参装饰器:给装饰器添加一个参数.来控制装饰器的行为. @auth(参数) auth里层的函数名 = auth(参数) 被装饰的函数名 = auth里层的函数名(被装饰的函数名) 被装饰的函数名( ...

  9. Netty4的介绍(一)

    Netty是由JBOSS提供给的一个java开源框架.Netty提供异步的.事件驱动的网络应用框架和工具,用以快速开发高性能.高可靠的网络服务器和客户端程序. 也就是说,Netty是一个基于NIO的客 ...

  10. Computer Network Chapter3 solution

    1.校验和:各数值相加,将溢出位加到最低位,之后将结果取反.若校验和全为0,则说明接收数据正确. 2.停等协议及计算信道利用率:利用率=(L/C)/(L/C+2*传输时延) 3.回退N帧协议(协议5) ...