java-数据库连接,分层实现增删改查测试
成员属性类:
public class Dog {
private int number;
private String name;
private String strain;
private String sex;
private int age;
private String matters; public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getStrain() {
return strain;
}
public void setStrain(String strain) {
this.strain = strain;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getMatters() {
return matters;
}
public void setMatters(String matters) {
this.matters = matters;
}
}
逻辑方法类:
package com.zhidisoft.dao; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import com.zhidisoft.entity.Dog; //用来实现数据库的操作 连接、释放数据库 通用的增删改查
public class DatabaseAction {
Connection conn = null;
//连接数据库
public Connection getConnection(){
String url = "jdbc:mysql://127.0.0.1:3306/test?" + "user=root&password=root&useUnicode=true&characterEncoding=UTF8";
try {
Class.forName("com.mysql.jdbc.Driver");//声明驱动的jar包
conn = DriverManager.getConnection(url);//按照url提供的路径连接服务器
} catch (ClassNotFoundException | SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}// 动态加载mysql驱动
return conn;
}
//向数据库插入信息
public int zhuce(Dog dog){
conn=this.getConnection();//调用连接数据库方法,连接服务器
String sql="insert into Dog() values("+dog.getNumber()+",'"+dog.getName()+"','"+dog.getStrain()+"','"+dog.getSex()+"',"+dog.getAge()+",'"+dog.getMatters()+"')";
Statement st;
int result=0;
try {
st = conn.createStatement();
result=st.executeUpdate(sql);//执行sql语句,返回结果为int类型,受影响的行数
conn.close();//关闭数据库连接
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result;
} public int shanchu(int number){
conn=this.getConnection();
String sql = "delete from Dog where number = "+number;
Statement st;
int result = 0;
try {
st = conn.createStatement();
result = st.executeUpdate(sql);
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result;
} public int genggai(String name,String matters){
conn=this.getConnection();
String sql = "update Dog set matters ='"+matters+"' where name = '"+name+"'";
Statement st;
int result = 0;
try {
st = conn.createStatement();
result = st.executeUpdate(sql);
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result;
} public void chazhao(Dog dog){
conn=this.getConnection();
String sql = "select * from Dog";
Statement st;
try {
st = conn.createStatement();
ResultSet rs = st.executeQuery(sql);
while (rs.next()) {//遍历输出查询记录
System.out.println("编号:"+rs.getInt("number")+"\t姓名 "+rs.getString("name")+"\t品种:"+rs.getString("strain")+"\t性 别:"+rs.getString("sex")+"\t年龄:"+rs.getInt("age")+"\t病情:"+rs.getString("matters"));
}
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} }
测试类:控制器:根据不同的功能调用不同的方法
import java.sql.SQLException;
import java.util.Scanner;import com.zhidisoft.dao.DatabaseAction;
import com.zhidisoft.entity.Dog; public class Test {
public static void main(String[] args) throws SQLException {
DatabaseAction dz=new DatabaseAction();//实例化方法类
//专注于业务逻辑
System.out.println("欢迎来到宠物医院,请选择操作:1.注册 2.删除 3.更改 4.查询");
@SuppressWarnings("resource")
Scanner input=new Scanner(System.in);
Dog dog = new Dog();
String choice=input.next();
if(choice.equals("1")){
//进行注册操作
//收集数据 调用数据库的插入方法实现注册
System.out.println("输入宠物的编号:");
dog.setNumber(Integer.valueOf(input.next()));
System.out.println("输入宠物的名字:");
dog.setName(input.next());
System.out.println("输入宠物的品种:");
dog.setStrain(input.next());
System.out.println("输入宠物的性别:");
dog.setSex(input.next());
System.out.println("输入宠物的年龄:");
dog.setAge(Integer.valueOf(input.next()));
System.out.println("输入宠物的病情:");
dog.setMatters(input.next()); //调用dao层的代码实现数据的插入
int result=dz.zhuce(dog);
if (result == 1) {//受影响行数为1,插入成功
System.out.println("信息注册成功");
}else{
System.out.println("注册不成功,请检查输入信息是否完善");
}
} if (choice.equals("2")) {
System.out.println("请输入要删除的编号:");
dog.setNumber(Integer.valueOf(input.next()));
int result = dz.shanchu(dog.getNumber());
if (result != 0) {//有删除的记录,受影响行数不为零
System.out.println("编号相对应狗信息删除成功");
}else{
System.out.println("未找到此编号的狗信息");
}
} if (choice.equals("3")) {
System.out.println("请输入要更病情的狗的名字");
dog.setName(input.next());
System.out.println("请输入要更改的病情");
dog.setMatters(input.next());
int result = dz.genggai(dog.getName(), dog.getMatters());
if (result == 0) {//修改成功,受影响条目不为零
System.out.println("没有找到名字叫做"+dog.getName()+"的狗");
}else{
System.out.println("更改成功");
}
} if (choice.equals("4")) {//调用查询方法,遍历输出所有结果
dz.chazhao(dog);
}
}
}
java-数据库连接,分层实现增删改查测试的更多相关文章
- Java连接MySQL数据库增删改查通用方法
版权声明:本文为博主原创文章,未经博主允许不得转载. Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类 ...
- Java实现mongodb原生增删改查语句
Java实现mongodb原生增删改查语句 2018-03-16 自动化测试时,需校验数据库数据,为了快速自动化,在代码中用原生增删改查语句操作mongodb 结构 代码 0 pom.xml < ...
- Java操作数据库实现"增删改查"
本文主要讲解JDBC操作数据库 主要实现对MySql数据库的"增删改查" 综合概述: JDBC的常用类和接口 一 DriverManager类 DriverManage类 ...
- eclipse控制台下实现jdbc简单的增删改查测试
1.现在MySQL中创建一个表 2.首先创建一个类 //导入的包 import java.sql.Connection;import java.sql.DriverManager;import jav ...
- java操作数据库:增删改查
不多bb了直接上. 工具:myeclipse 2016,mysql 5.7 目的:java操作数据库增删改查商品信息 test数据库的goods表 gid主键,自增 1.实体类Goods:封装数据库数 ...
- Java web 简单的增删改查程序(超详细)
就是简单的对数据进行增删改查.代码如下: 1.bean层:用来封装属性及其get set方法 toString方法,有参构造方法,无参构造方法等. public class Bean { privat ...
- java web数据库的增删改查详细
本次课上实验是完成数据库的增删改查. 包括增加用户信息.删除用户信息.多条件查找用户信息.修改用户信息(主要是复选框单选框等的相关操作.) 下面下看一下各个界面的样子. 总页面:显示全部页面:增加页面 ...
- Java实现简单的增删改查操作
需求分析:通过数组 ,完成 对学生信息的 管理 (增删改查)创建1个 学生类创建1个 CRUD的类 – 学生管理类 并测试 在这个程序中我只运用了两个类进行操作 package com.hopu.de ...
- Java连接MongoDB进行增删改查
1.导入必须的包: 详情看项目:http://pan.baidu.com/s/1cvDAOY 2.通过Myeclipse创建WEB项目 3. 3.bean:创建实体类 package com.bean ...
随机推荐
- sed,n,N,d,D,p,P,h,H,g,G,x,解析
原文地址 这篇文章主要是我参考命令的,直接复制粘贴,有问题请拍砖 A. sed执行模板=sed '模式{命令1;命令2}' 即逐行读入模式空间,执行命令,最后输出打印出来 B. p打印当前模式空间所有 ...
- SQL语句-create语句
SQL语法基础 Create database语句 Create database语句是在MySQL实例上创建一个指定名称的数据 库,create schema语句的语义和create databas ...
- 【Thinkphp 5】 整合邮箱类 phpmailer实现邮件发送
第一步:下载phpmailer文件,主要用到的文件只有箭头指向的两个,thinkphp5中,把class.phpmailer.php改成了phpmailer.php 第二步: 将phpmailer文件 ...
- Android开发之漫漫长途 Fragment番外篇——TabLayout+ViewPager+Fragment
该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,我会尽量按照先易后难的顺序进行编写该系列.该系列引用了<Android开发艺术探索>以及<深入理解And ...
- java之拦截器Interceptor
1,拦截器的概念 java里的拦截器是动态拦截Action调用的对象,它提供了一种机制可以使开发者在一个Action执行的前后执行一段代码,也可以在一个Action执行前阻止其执行,同时也提供了 ...
- spring jdbc踩坑日记,new JdbcTemplate 为null导致UserDao一直为null
private DataSource datasource; private JdbcTemplate jdbcTemplateObject; //设置注入 public void setdataso ...
- SEO页面优化以及如何对单页面应用进行SEO优化
一.简介 1.何为SEO? SEO(search engine optimization),翻译为搜索引擎优化,是利用搜索引擎的搜索规则来提高在相关搜索引擎的排名以及访问量的方式. 2.目的 为了获取 ...
- JDBC访问及操作SQLite数据库
SQLite 是一个开源的嵌入式关系数据库,其特点是高度便携.使用方便.结构紧凑.高效.可靠. 与其他数据库管理系统不同,SQLite 的安装和运行非常简单,在大多数情况下,只要确保SQLite的二进 ...
- POJ 2065 SETI [高斯消元同余]
题意自己看,反正是裸题... 普通高斯消元全换成模意义下行了 模模模! #include <iostream> #include <cstdio> #include <c ...
- POJ1509 Glass Beads [后缀自动机]
题意: 给一个字符串S,每次可以将它的第一个字符移到最后面,求这样能得到的字典序最小的字符串.输出开始下标 练习SAM第一题! SS构造SAM,然后从开始尽量走最小走n步就可以啦 什么?开始位置?!R ...