每天叫醒自己的不是闹钟,而是梦想

conn层

package conn;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException; import com.mysql.jdbc.Statement; public class Conn {
/*Statement stmt;
* 该对象用于执行静态SQL语句并返回它产生的结果。 默认情况下,只有一个ResultSet对象每Statement对象可以同时打开。因此,如果一个ResultSet对象的阅读是交错的另一个阅读,每个人都必须有不同的Statement对象产生。在Statement接口的所有执行方法隐式关闭的声明,目前ResultSet对象如果打开一个存在。
简单来说,就是一个结果对应一个Statement
本次实现增删改查。需要4个返回结果,所以定义4个Statement对象
*/
Statement stmt;
Statement stmt1;
Statement stmt2;
Statement stmt3; public Conn() //本段代码块构造函数,初始化连接数据库
{
try {
Class.forName("com.mysql.jdbc.Driver");//加载jdbc驱动
String url = "jdbc:mysql://localhost:3306/test?user=root&password=password&useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false";
Connection con=DriverManager.getConnection(url);//连接数据库
stmt =(Statement) con.createStatement();
stmt1 =(Statement) con.createStatement();
stmt2 =(Statement) con.createStatement();
stmt3 =(Statement) con.createStatement();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
public boolean insert(String sql) //插入。Statement对象调用executeupdate方法执行sql语句。 成功与否返回布尔型。
{
boolean flag=true; //flag标识
try {
stmt.executeUpdate(sql);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
flag=false;//捕获到异常。执行失败。返回false;
}
return flag;
}
public boolean update(String sql)
{
boolean flag=true;
try {
stmt1.executeUpdate(sql);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
flag=false;
}
return flag;
}
public boolean delect(String sql)
{
boolean flag=true;
try {
stmt2.executeUpdate(sql);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
flag=false;
}
return flag;
}
public ResultSet select(String sql) throws Exception
{ return stmt3.executeQuery(sql); }
}

  dao层

package dao;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList; import com.mysql.jdbc.ResultSetImpl; import bean.Student;
import conn.Conn;
/*本类中拼接sql语句 本类为实现接口方法
* 用于用户调用
* 传入conn连接数据库类
* 节后的实现后缀用impl
*
* */
public class StudentDao implements IStudentDao {
Conn conn=new Conn();
@Override
public boolean insertStudent(Student student) {
// TODO Auto-generated method stub
String name=student.getName();
int age=student.getAge();
int sex=student.getSex();
String sql = "INSERT INTO student(`name`,`age`,`sex`) VALUES('"+name+"',"+age+","+sex+");"; return conn.insert(sql);
} @Override
public boolean updateStudent(Student student) {
int id=student.getId();
String name=student.getName();
int age=student.getAge();
int sex=student.getSex();
String sql = "UPDATE student set `name`='"+name+"',age="+age+",sex="+sex+" WHERE id="+id+"";
// String sql = "UPDATE student SET `name`='"+name+"'"+",age="+age+",sex="+sex+" WHERE id="+id;
return conn.update(sql);
} @Override
public boolean delectStudent(Student student) {
// TODO Auto-generated method stub
int id=student.getId();
String sql = "DELETE FROM student where id="+id;
return conn.delect(sql);
} @Override
public ArrayList<Student> selectStudent() {
// TODO Auto-generated method stub
String sql="select *from student;";
ResultSet set=null;
ArrayList<Student> list=new ArrayList<>();
try {
set=conn.select(sql);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
while(set.next())
{
Student student=new Student();
student.setId(set.getInt("id"));
student.setName(set.getString("name"));
student.setAge(set.getInt("age"));
student.setSex(set.getInt("sex"));
list.add(student);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
} }

  

package dao;

import java.util.ArrayList;

import bean.Student;

public interface IStudentDao {
/*本接口写方法。用于其他类继承调用
* 使用其他包类是。需要先导入
* 查询结果返回数组
* 接口
*
* */
public boolean insertStudent(Student student);
public boolean updateStudent(Student student);
public boolean delectStudent(Student student);
public ArrayList<Student> selectStudent();
}

  server

package server;

import java.util.ArrayList;

import bean.Student;

public interface IStudentServer {
public boolean insertStudent(Student student);
public boolean deleteStudent(Student student);
public boolean updateStudent(Student student);
public ArrayList<Student> selectAllStudent(); }

 

package serverImpl;

import java.util.ArrayList;

import bean.Student;
import dao.StudentDao;
import server.IStudentServer; public class ServerStudent implements IStudentServer{
StudentDao studentDao= new StudentDao(); @Override
public boolean insertStudent(Student student) {
// TODO Auto-generated method stub
return studentDao.insertStudent(student);
} @Override
public boolean deleteStudent(Student student) {
// TODO Auto-generated method stub
return studentDao.delectStudent(student);
} @Override
public boolean updateStudent(Student student) {
// TODO Auto-generated method stub
return studentDao.updateStudent(student);
} @Override
public ArrayList<Student> selectAllStudent() {
// TODO Auto-generated method stub
return studentDao.selectStudent();
} }

  action

package action;

import java.util.ArrayList;

import bean.Student;
import serverImpl.ServerStudent; public class StudentAction {
ServerStudent serverStudent =new ServerStudent();
public String insertStudent(Student student)
{
boolean flag=serverStudent.insertStudent(student);
if(flag==true)
return "插入成功";
else
return "插入失败";
}
public String delectStudent(Student student)
{ boolean flag=serverStudent.deleteStudent(student);
if(flag==true)
return "刪除成功";
else
return "刪除失败";
}
public String updateStudent(Student student)
{ boolean flag=serverStudent.updateStudent(student);
if(flag==true)
return "修改成功";
else
return "修改失败";
}
public String selectStudent()
{
ArrayList<Student> student=serverStudent.selectAllStudent();
String ss = "";
for(Student chaoba:student) {
ss += "id:"+chaoba.getId();
ss += " name:"+chaoba.getName();
ss += " age:" + chaoba.getAge();
ss += " sex:" + (chaoba.getSex()==1?"男":"女");
ss += "\r\n";
}
return ss;
}
}

  

bean 业务实体

package bean;
/*Student类。用做业务实体,
* 进行复制。传递获取
*
*
*
*
* */
public class Student {
private int id;
private String name;
private int age;
private int sex;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public int getSex() {
return sex;
}
public void setSex(int sex) {
this.sex = sex;
} }

  

 *-------------------------------------------*
By:暮雪超霸博客:http://www.cnblogs.com/chaoba/
 *-------------------------------------------*

JDBC数据连接之增删改查MVC的更多相关文章

  1. 通过JDBC进行简单的增删改查

    通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...

  2. 通过JDBC进行简单的增删改查(以MySQL为例) 目录

    通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...

  3. Java通过JDBC进行简单的增删改查(以MySQL为例)

    Java通过JDBC进行简单的增删改查(以MySQL为例) 目录: 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JD ...

  4. C# - VS2019 通过DataGridView实现对Oracle数据表的增删改查

    前言 通过VS2019建立WinFrm应用程序,搭建桌面程序后,通过封装数据库操作OracleHelper类和业务逻辑操作OracleSQL类,进而通过DataGridView实现对Oracle数据表 ...

  5. AngularJS中使用$http对MongoLab数据表进行增删改查

    本篇体验使用AngularJS中的$http对MongoLab数据表进行增删改查. 主页面: <button ng-click="loadCourse()">Load ...

  6. Mysql数据表的增删改查

    ---恢复内容开始--- Mysql数据表的增删改查 1.创建表   语法:CREATE TABLE 表名(字段1,字段2,字段3.......) CREATE TABLE `users` ( `us ...

  7. jQuery EasyUI/TopJUI实现数据表格的增删改查功能(不写js,纯HTML实现!!!)

    jQuery EasyUI/TopJUI实现数据表格的增删改查功能(不写js,纯HTML实现!!!) 废话不多说,直接贴上代码 <table id="configEdatagrid&q ...

  8. MySQL数据分析(16)— 数据操作之增删改查

    前面我们说学习MySQL要从三个层面,四大逻辑来学,三个层面就是库层面,表层面和数据层面对吧,数据库里放数据表,表里放数据是吧,大家可以回忆PPT中jacky的这图,我们已经学完了库层面和表层面,从本 ...

  9. Redis简单的数据操作(增删改查)

    #Redis简单的数据操作(增删改查): 字符串类型 string 1. 存储: set key value 127.0.0.1:6379> set username zhangsan OK 2 ...

随机推荐

  1. 【原创】Linux虚拟化KVM-Qemu分析(七)之timer虚拟化

    背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: KVM版本:5.9 ...

  2. 第5.4节 Python函数中的变量及作用域

    一.函数中的变量使用规则 函数执行时,使用的全局空间是调用方的全局空间,参数及函数使用的局部变量存储在函数单独的局部名字空间内: 函数的形参在函数中修改了值时,并不影响调用方本身的数据,但如果形参是一 ...

  3. 第7.24节 Python案例详解:使用property函数定义属性简化属性访问代码实现

    第7.24节 Python案例详解:使用property函数定义属性简化属性访问代码实现 一.    案例说明 本节将通过一个案例介绍怎么使用property定义快捷的属性访问.案例中使用Rectan ...

  4. PyQt学习随笔:QTableWidget项sizeHint的作用以及与QHeadView的sectionResizeMode、ResizeToContents的关系

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在学习QTableWidgetItem的sizeHint()方法时,Qt自带材料中介绍sizeHin ...

  5. PyQt(Python+Qt)学习随笔:QListWidget查找项的findItems方法

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QListWidget列表部件的findItems方法用于查找列表部件是否有满足条件的项,调用语法如 ...

  6. Oracle函数使用1

    一.字符串处理函数 1.ascii(x):返回字符的ASCII. SQL语句:select ascii('a') from dual; dual:空表,每创建一个用户都会生成这样一个dual表,表中只 ...

  7. Scrum 冲刺第二天

    一.每日站立式会议 1.会议内容 1)进行每日工作汇报 张博愉: 昨天已完成的工作:制定测试计划.博客编写 今日工作计划:测试mappe里的接口 工作中遇到的困难:对测试接触得较少 张润柏: 昨天已完 ...

  8. ELK-Kibana汉化

    https://github.com/anbai-inc/Kibana_Hanization  补丁包 教程:1:首先,我们先杀死了Kibana进程,其实,教程说不用重启或关闭Kibana,但是,我们 ...

  9. uni-app中使用sass

    uni-app在创建时,工程目录下会有个uni.scss文件,我们可以直接在里面定制化scss变量. 全局scss中的坑: 1.如果要引用全局外部scss文件,可以考虑在uni.scss这个系统全局s ...

  10. STL—— 容器(vector)数据插入insert()方法 的返回值

    vector 容器下的 insert() 方法拥有返回值,由于insert() 方法拥有4种重载函数,他的返回值不尽相同. 第一种,插入单个元素后的返回值: 1 #include <iostre ...