struts+hibernate 请求数据库增删改查(小项目实例)

时间:2022-10-29 17:12:58
 

StudentAction.java

package com.action;

import java.util.ArrayList;
import java.util.List;
import java.util.Map; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.apache.struts2.ServletActionContext;
import org.omg.CORBA.Request; import com.dao.StudentDao;
import com.dao.imp.StudentDaoImp;
import com.entity.Student;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport; public class StudentAction extends ActionSupport{
private StudentDao dao=new StudentDaoImp();
public StudentDao getDao() {
return dao;
}
public void setDao(StudentDao dao) {
this.dao = dao;
} private int id;
private String name;
private String password;
private String email;
private String sex;
private int age;
private int page=1;
private Student student=new Student(); 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 String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
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 int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
} @Override
public void validate() {
// TODO Auto-generated method stub
if(student.getName()==null||student.getName().trim().equals(""))
{
this.addFieldError("name", "姓名不能为空");
}
if(student.getPassword()==null||student.getPassword().trim().equals(""))
{
this.addFieldError("password", "密码不能为空");
} }
//重写validate()校验方法 public String findStudents(){
/*耦合方式
* HttpServletRequest request=ServletActionContext.getRequest();
HttpServletResponse response=ServletActionContext.getResponse();
*/
ActionContext ctx=ActionContext.getContext();
Map request=(Map)ctx.get("request");
//可以直接拿到session ctx.getSession();
//ctx.getApplication();
List<Student> students=dao.getStudentsByPage("from Student",page);
//存放到request 属性里面返回前台
//page已经在配置成属性 不用set前台也能获得到
request.put("students", students);
//通过拦截器将其放到attribute里
/*耦合方式request.setAttribute("students", students);*/ //request.getSession().getServletContext();可以拿到session
//servlet中的都可以拿得到
return "findStudents"; } public String saveStudent(){ student.setId(id);
student.setAge(age);
student.setName(name);
student.setEmail(email);
student.setPassword(password);
student.setSex(sex);
dao.saveStudent(student);
return "saveStudent";
} public String deleteStudent(){
dao.deleteStudent(id);
return "deleteStudent"; }
}

student.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <constant name="struts.enable.DynamicMethodInvocation" value="true" />
<constant name="struts.devMode" value="false" /> <package name="student" namespace="/student" extends="struts-default"> <action name="student_*" class="com.action.StudentAction" method="{1}">
<result name ="saveStudent" type="chain">student_findStudents</result>
<!-- action之间的跳转 type="chain"-->
<result name ="deleteStudent" type="chain">student_findStudents</result>
<result name ="findStudents">/student.jsp</result>
<result name="input">/student_add.jsp</result>
<!-- 出现错误返回当前页面 -->
</action> </package> </struts>

struts.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <include file ="config/student.xml"></include> </struts>

student.java

package com.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id; @Entity
public class Student{
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private int id;
private String name;
private String password;
private String email;
private String sex; public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
private int age; public Student() {
super();
}
public Student(String name, int age) {
super();
this.name = name;
this.age = age;
}
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;
} }

studentDao.java

package com.dao;

import java.util.List;

import com.entity.Student;

public interface StudentDao {
public void saveStudent(Student student);
public void deleteStudent(int id);
public List<Student> getStudents(String hql);
public List<Student> getStudentsByPage(String hql,int page) ;
}

StudentDaoImp.java

package com.dao.imp;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction; import com.dao.StudentDao;
import com.entity.Student;
import com.util.HibernateUtils; public class StudentDaoImp implements StudentDao {
private int pageSize=10;
@Override
public void saveStudent(Student student) {
// TODO Auto-generated method stub
Session session=HibernateUtils.getSession();
Transaction tx=session.beginTransaction();
session.saveOrUpdate(student);
tx.commit();
HibernateUtils.closeSession(session);
} @Override
public void deleteStudent(int id) {
// TODO Auto-generated method stub
Session session=HibernateUtils.getSession();
Transaction tx=session.beginTransaction();
// 1.sessionɾ��
Student stu=(Student)session.get(Student.class, id);
session.delete(stu);
//2.����query�ӿ�ɾ�� session.createQurey(delete from Student where id=??)
//q.executeUpdate()
tx.commit();
HibernateUtils.closeSession(session);
} @Override
public List<Student> getStudents(String hql) {
// TODO Auto-generated method stub
Session session=HibernateUtils.getSession();
Query q=session.createQuery(hql); return q.list();
}
@Override
public List<Student> getStudentsByPage(String hql,int page) {
// TODO Auto-generated method stub
Session session=HibernateUtils.getSession();
Query q=session.createQuery(hql);
int begin=(page-1)*pageSize+1;
q.setFirstResult(begin-1).setMaxResults(pageSize);
return q.list();
} }

前台页面student.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link href="${pageContext.request.contextPath}/css/bootstrap.css" type="text/css" rel="stylesheet"/>
<script type="text/javascript" src="js/jquery-2.0.3.min.js"></script>
<script type="text/javascript" src="js/bootstrap.js"></script>
<style type="text/css">
h1,h3,table{
margin: 0 auto;
text-align: center;
}
</style> </head> <body>
<h1>学生信息表</h1>
<table class="table table-striped table-bordered">
<tr><td>学号</td><td>姓名</td><td>年龄</td><td>操作</td>
<c:forEach items="${requestScope.students}" var="student">
<tr><td>${student.id }</td><td>${student.name}</td><td>${student.age }</td>
<td><a href="saveStudentServlet?id=${student.id }">更新</a>&nbsp;&nbsp;<a href="student_deleteStudent?id=${student.id }">删除</a></td>
</tr> </c:forEach> </table>
<h3><span><a href="student_findStudents.action?page=${page-1 }">上一页</a>&nbsp;
<a href="student_findStudents.action?page=${page+1 }">下一页</a>&nbsp;
当前是第${page }页
<%-- a href="student_findStudents.action?page=${page-1 }" --%>
<!-- student是action name findstudents是方法
也可以写绝对目录 /项目名称/namespace/actionname.action-->
</span></h3>
</body>
</html>

student_add.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@taglib prefix="s" uri="/struts-tags" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link href="${pageContext.request.contextPath}/css/bootstrap.css" type="text/css" rel="stylesheet"/>
<script type="text/javascript" src="js/jquery-2.0.3.min.js"></script>
<script type="text/javascript" src="js/bootstrap.js"></script>
<style type="text/css">
h1,h3,table{
margin: 0 auto;
text-align: center;
}
input{width:200px}
</style>
</head> <body>
<div class="container" style="width:500px;height: 500px"> <h1>增加学生信息</h1> <form role="form" action="student/student_saveStudent" method="post">
<input type="hidden" value="${stu.id }" name="id"/>
<div class="form-group">
<label for="email">邮箱</label>
<input type="email" class="form-control" value="${stu.email }" name="email" id="email" placeholder="Enter email">
</div>
<div class="form-group">
<label for="name">姓名</label>
<input type="text" class="form-control" name="name" value="${stu.name }" id="name" placeholder="name">
</div>
<div class="form-group">
<label for="password">密码</label>
<input type="password" class="form-control" name="password" value="${stu.password }" id="password" placeholder="Password">
</div>
<div class="form-group">
<label for="age">年龄</label>
<input type="text" class="form-control" id="age" name="age" value="${stu.age }">
</div>
<div class="radio">
<label>
<input type="radio" class="form-control" id="sex" name="sex" value="male"/>男
<input type="radio" class="form-control" id="sex1" name="sex" value="female" checked="checked"/>女
</label>
</div>
<button type="submit" class="btn btn-default">保存</button>
</form>
</div>
</body>
</html>

struts+hibernate 请求数据库增删改查(小项目实例)的更多相关文章

  1. go——beego的数据库增删改查

    一直都不理解使用go语言的时候,为什么还要自己去装beego,以为使用go便可以解决所有的问题,结果在朋友的点拨下,才意识到: go与beego的关系就好比是nodejs与thinkjs的关系,因此也 ...

  2. spring--boot数据库增删改查

    spring--boot数据库增删改查 数据库配置:(必须配置),我写的文件是yml的,和properties是相同的 1 spring: 2 datasource: 3 driver-class-n ...

  3. node&period;js封装数据库增删改查

    数据库增删改查的封装 小编不容易 const sql = { insert: function (Collection, insertData) { return new Promise((resol ...

  4. Python实现mysql数据库增删改查

    利用python操作mysql数据库用法简单,环境配置容易,本文将实现对库增.删.改.查的简易封装!   1. 环境配置 安装第三方包  ,导入模块 mysql.connector  pip inst ...

  5. Yii2&period;0高级框架数据库增删改查的一些操作(转)

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

  6. 2&period; MongoDB基本操作 —— 用Mongo&period;exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  7. &lpar;转&rpar;SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  8. Yii2&period;0高级框架数据库增删改查的一些操作

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

  9. WindowsPhone8 数据库增删改查

    今天第一次在博客园发表文章,如果有的地方写的不对,还请大家指出! 1.这就是一个简单wp8数据库增删改查 1.创建数据表Person [Table] public class Person : INo ...

随机推荐

  1. 【UOJ &num;14】【UER &num;1】DZY Loves Graph

    http://uoj.ac/problem/14 题解很好的~ 不带路径压缩的并查集能保留树的原本形态. 按秩合并并查集可以不用路径压缩,但是因为此题要删除,如果把深度当为秩的话不好更新秩的值,所以把 ...

  2. 磁盘IO

    基本概念: 在数据库优化和存储规划过程中,总会提到IO的一些重要概念,在这里就详细记录一下,个人认为对这个概念的熟悉程度也决定了对数据库与存储优化的理解程度,以下这些概念并非权威文档,权威程度肯定就不 ...

  3. js的并行加载与顺序执行

    javaScript文件(下面简称脚本文件)需要被HTML文件引用才能在浏览器中运行.在HTML文件中可以通过不同的方式来引用脚本文件,我们需要关注的是,这些方式的具体实现和这些方式可能会带来的性能问 ...

  4. Ceph相关博客、网站(256篇OpenStack博客)

    官网文档: http://docs.ceph.com/docs/master/cephfs/ http://docs.ceph.com/docs/master/cephfs/createfs/   ( ...

  5. js脚本语言(数组)

    定义:给数据Array(1,3.14,"aa")给长度(Array(5))使用方括号定义[1,3.14,"aa"] 属性:lenght(数据的长度) 方法:pu ...

  6. TOJ 1214&colon; 数据结构练习题&horbar;&horbar;线性表操作

    描述 请你定义一个线性表,可以对表进行"在某个位置之前插入一个元素"."删除某个位置的元素"."清除所有元素"."获取某个位置的元 ...

  7. Android简易实战教程--第三十六话《电话录音》

    今天完成一个简单的电话录音功能,即接通电话后,立即录下自己打电话的声音.实现起来比较简单:一个服务,一个TelephonyManager.一个MediaRecorder就够了. 1.布局提供一个开启录 ...

  8. 将tomcat添加为linux系统服务

    前言 在博客 --> virtualBox安装centos,并搭建tomcat中,讲到了centos下搭建tomcat环境,发现启动tomcat不是那么方便,要是忘记路径了,那就更麻烦了!当然了 ...

  9. 用basicTrendline画一元线性回归直线的置信区间

    感慨统计学都还给老师了..恶补! R安装包的时候貌似需要用管理员权限启动,否则安装不了,国内镜像卡得渣渣,还是国外镜像真香~选择hongkong就好了. install.packages(" ...

  10. Spring Boot 静态资源映射与上传文件路由配置

    默认静态资源映射目录 默认映射路径 在平常的 web 开发中,避免不了需要访问静态资源,如常规的样式,JS,图片,上传文件等;Spring Boot 默认配置对静态资源映射提供了如下路径的映射 /st ...