java实现连接mysql数据库单元测试查询数据的实例代码
作者:jingxian 发布时间:2024-01-26 12:38:47
标签:java,连接,mysql,数据库
1、按照javaweb项目的要求逐步建立搭建起机构,具体的类包有:model 、db、dao、test;
具体的架构详见下图:
2、根据搭建的项目架构新建数据库test和数据库表t_userinfo并且添加对应的测试数据; (这里我使用的是绿色版的数据库,具体的下载地址:http://pan.baidu.com/s/1mg88YAc)
具体的建立数据库操作详见下图:
3、编写包中的各种类代码,具体参考代码如下:
UserInfo.java
/**
* FileName: UserInfo.java
* @Description: TODO封装对象的信息
* Copyright: personage
* Company personage
* @author: gaoxing
* @version V1.0
* Createdate: 2014-5-25 下午2:26:41
*
* Modification History:
* Date Author Version Discription
* -----------------------------------------------------------------------------------
* 2014-5-25 GX 1.0 1.0
* Why & What is modified: <修改原因描述>
*/
package com.org.user.model;
/**
* @ClassName: UserInfo
* @Description:TODO封装对象的信息
* @author: gaoxing
* @date: 2014-5-25 下午2:26:41
*/
public class UserInfo {
private int userid;
private String username;
private String password;
/**
* @Title: UserInfo
* @Description: TODO(描述这个方法的作用)
* @param: @param userid
* @param: @param username
* @param: @param password
* @throws
*/
public UserInfo(int userid, String username, String password) {
super();
this.userid = userid;
this.username = username;
this.password = password;
}
/**
* @Title: UserInfo
* @Description: TODO无参的构造方法
* @param:
* @throws
*/
public UserInfo() {
super();
}
public int getUserid() {
return userid;
}
public void setUserid(int userid) {
this.userid = userid;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
UserInfoDBManger.java
/**
* FileName: UserInfoDBManger.java
* @Description: TODO 连接数据库的操作
* Copyright: personage
* Company personage
* @author: gaoxing
* @version V1.0
* Createdate: 2014-5-25 下午2:47:38
*
* Modification History:
* Date Author Version Discription
* -----------------------------------------------------------------------------------
* 2014-5-25 GX 1.0 1.0
* Why & What is modified: <修改原因描述>
*/
package com.org.user.db;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.PreparedStatement;
/**
* @ClassName: UserInfoDBManger
* @Description:TODO连接数据库的操作
* @author: gaoxing
* @date: 2014-5-25 下午2:47:38
*/
public class UserInfoDBManger {
private static Connection conn = null;
private PreparedStatement ps = null;
private ResultSet rs = null;
public static Connection getConn() {
String url = "jdbc:mysql://localhost:3306/test";
try {
Class.forName("com.mysql.jdbc.Driver");
try {
conn = (Connection) DriverManager.getConnection(url, "root",
"mysql");
} catch (SQLException e) {
System.out.println(e.getMessage());
}
} catch (ClassNotFoundException e) {
System.out.println(e.getMessage());
}
return conn;
}
public void close() {
try {
rs.close();
ps.close();
conn.close();
} catch (SQLException e) {
e.getMessage();
}
}
}
UserInfoDao.java
/**
* FileName: UserInfoDao.java
* @Description: TODO 处理通过数据库的连接进行操作对象信息
* Copyright: personage
* Company personage
* @author: gaoxing
* @version V1.0
* Createdate: 2014-5-25 下午2:36:09
*
* Modification History:
* Date Author Version Discription
* -----------------------------------------------------------------------------------
* 2014-5-25 GX 1.0 1.0
* Why & What is modified: <修改原因描述>
*/
package com.org.user.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.PreparedStatement;
import com.org.user.db.UserInfoDBManger;
import com.org.user.model.UserInfo;
/**
* @ClassName: UserInfoDao
* @Description:TODO处理通过数据库的连接进行操作对象信息
* @author: gaoxing
* @date: 2014-5-25 下午2:36:09
*/
public class UserInfoDao {
Connection conn=null;
PreparedStatement ps=null;
ResultSet rs=null;
public List<UserInfo> find(){
List<UserInfo> list=new ArrayList<UserInfo>();
String sql="select * from t_userinfo ";
conn=UserInfoDBManger.getConn();
try {
ps=(PreparedStatement) conn.prepareStatement(sql);
rs=ps.executeQuery();
while (rs.next()) {
UserInfo ui=new UserInfo();
ui.setUserid(rs.getInt(1));
ui.setUsername(rs.getString(2));
ui.setPassword(rs.getString(3));
list.add(ui);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}
}
UserInfoTest.java
/**
* FileName: UserInfoTest.java
* @Description: TODO测试dao包的方法
* Copyright: personage
* Company personage
* @author: gaoxing
* @version V1.0
* Createdate: 2014-5-25 下午5:43:03
*
* Modification History:
* Date Author Version Discription
* -----------------------------------------------------------------------------------
* 2014-5-25 GX 1.0 1.0
* Why & What is modified: <修改原因描述>
*/
package com.org.user.test;
import static org.junit.Assert.*;
import java.util.List;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import com.org.user.dao.UserInfoDao;
import com.org.user.model.UserInfo;
/**
* @ClassName: UserInfoTest
* @Description:TODO 测试dao包的方法
* @author: gaoxing
* @date: 2014-5-25 下午5:43:03
*/
public class UserInfoTest {
/**
* @Title: setUpBeforeClass
* @Description: TODO(描述这个方法的作用)
* @param: @throws java.lang.Exception
* @return: void
* @throws
*/
@BeforeClass
public static void setUpBeforeClass() throws Exception {
}
/**
* @Title: tearDownAfterClass
* @Description: TODO(描述这个方法的作用)
* @param: @throws java.lang.Exception
* @return: void
* @throws
*/
@AfterClass
public static void tearDownAfterClass() throws Exception {
}
/**
* Test method for {@link com.org.user.dao.UserInfoDao#find()}.
*/
@Test
public void testFind() {
UserInfoDao udao=new UserInfoDao();
List<UserInfo> list=udao.find();
for (int i = 0; i < list.size(); i++) {
UserInfo ui=list.get(i);
System.out.println("名称: "+ui.getUsername()+"密码: "+ui.getPassword());
}
}
}
4、在编写好类内容之后,在搭建项目过程中要加入辅助的JUnit的测试包junit.jar,同时也要导入数据库的连接mysq-connector-java-5.1.7-bin.jar sqljdbc.jar,这样才可以连接到数据库;
5、所有的工作做好之后,就可以启动服务进行运行了查看结果了,如果在JUnit测试台和控制台出现如下结果就表示项目运行成功了。
0
投稿
猜你喜欢
- 在Matplotlib实际使用中会有生成不同大小subplots的需求。import numpy as np import matplotl
- 前言print()函数用来将信息输出到控制台如果希望输出文字信息的同时,一起输出数据,可以使用格式化操作符%,格式化操作符负责处理字符串中的
- 使用MySQL,安全问题不能不注意。以下是MySQL提示的23个注意事项:1、如果客户端和服务器端的连接需要跨越并通过不可信任的网络,那么就
- SessionMiddleware 激活后,每个传给视图(view)函数的第一个参数``HttpRequest`` 对象都有一个 sessi
- 前言在前程无忧上投递简历发现有竞争力分析,免费能看到匹配度评价和综合竞争力分数,可以做投递参考计算方式综合竞争力得分应该越高越好,匹配度评语
- 在许多网页中,当鼠标移到一张图片上时,又弹出另一张图片,做这种广告条,要用到Macromedia DreamWeaver中的Lay
- 1. 编译出来的so比网上流传的其他方法小很多。2. language_level 是python的主版本号,如果python版
- 主要使用json模块,直接导入import json即可。小例子如下:#coding=UTF-8 import json info={} i
- Chrome Options常用的行为一般有以下几种:禁止图片和视频的加载:提升网页加载速度。添加代理:用于 * 某些页面,或者应对IP访
- 好想在2014结束前再赶出个10篇博文来,~(>_<)~,不写博客真不是一个好兆头,至少说明对学习的欲望和对知识的研究都不是那么
- 前言首先图片格式转换的方法有很多,但是转二进制字节流的,我搜了一下午终于在 stackoverflow上搜到了 说一下为什么要在线转这个图片
- 在数据存储过多时,我们会选择清除,不过有时候也需要找回一些我们之前删掉的数据。有的小伙伴可能会使用不同的方法分别完成,那么今天小编带来的_d
- 如何在约定时间显示特定的提示信息?<%Function Greeting()
- 本文实例讲述了PHP+redis实现添加处理投票的方法。分享给大家供大家参考,具体如下:<?php header("Cont
- 本文实例讲述了Python多线程下载文件的方法。分享给大家供大家参考。具体实现方法如下:import httplibimport urlli
- 前言随着人工智能研究的不断兴起,Python的应用也在不断上升,由于Python语言的简洁性、易读性以及可扩展性,特别是在开源工具和深度学习
- 译注:原文是StackOverflow上一个如何用程序读取迷宫图片并求解的问题,几位参与者热烈地讨论并给出了自己的代码,涉及到用Python
- 本文实例讲述了Python实现从URL地址提取文件名的方法。分享给大家供大家参考。具体分析如下:如:地址为 https://www.jb51
- 废话不多说了,直接步入正题,一个完整的神经网络一般由三层构成:输入层,隐藏层(可以有多层)和输出层。本文所构建的神经网络隐藏层只有一层。一个
- 在CSS中,模式(pattern)匹配规则决定那种样式规则应用于文档树(document tree)的哪个元素。这些模式叫着选择符(sele