SpringMVC整合Hibernate实现增删改查之按条件查询
更多精彩文章欢迎关注公众号“Java之康庄大道”

首先我贴出我项目的结构,只完成了条件查询的相关代码,增删改没有写。

1.新建一个动态Web工程,导入相应jar包,编写web.xml配置文件
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
</listener>
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
2.配置springmvc.xml
<!-- 配置自动扫描的包 -->
<context:component-scan base-package="com.tideway.springmvc"></context:component-scan> <mvc:annotation-driven/> <!-- 配置视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
hibernate配置文件:hibernate.cfg.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<mapping class="com.tideway.springmvc.entity.User"/>
</session-factory>
</hibernate-configuration>
配置数据源,连接池c3p0, spring-common.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd"> <!-- 配置数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/attendance" />
<property name="user" value="root" />
<property name="password" value="密码" />
</bean> <!-- 配置SessionFactory 通过spring提供的LocalSessionFactoryBean进行配置 -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<!-- 配置数据源 -->
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="classpath:hibernate.cfg.xml"></property>
</bean>
<!-- 配置一个事务管理器 -->
<bean id="transactionManager"
class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<!-- 添加一个通知取别名,然后决定管理哪一个事务管理器,***只是查询的话用不到事物 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="get*" read-only="true" />
<tx:method name="*" />
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut expression="execution(* com.tideway.springmvc.service.*.*(..))"
id="txPointcut" />
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut" />
</aop:config> </beans>
3.创建实体类User.java
package com.tideway.springmvc.entity; import java.util.Date; import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator;
@Entity
@Table(name="t_attendance")
public class User {
private int id;
private int enID;
private String name;
private Date datetime; @Id
@GenericGenerator(name="id",strategy="identity")
@GeneratedValue(generator="id")
@Column(name="id",unique=true,nullable=false)
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
@Column(name="EnID")
public int getEnID() {
return enID;
}
public void setEnID(int enID) {
this.enID = enID;
}
@Column(name="Name")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Column(name="DateTime")
public Date getDatetime() {
return datetime;
}
public void setDatetime(Date datetime) {
this.datetime = datetime;
} }
4.dao层接口
package com.tideway.springmvc.dao;
import java.util.List;
import com.tideway.springmvc.entity.User;
public interface UserDao {
/**
* dao层接口
* 查询打卡记录
* @param EnID 工号
* @param dateafter 起止日期
* @param datebefore 截至日期
* @return
*/
public List<User> getUser(String EnID,String dateafter,String datebefore);
}
5.dao层接口实现类
package com.tideway.springmvc.daoimpl; import java.util.List;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import com.tideway.springmvc.dao.UserDao;
import com.tideway.springmvc.entity.User; //@Repository用于标注数据访问组件,即DAO组件
@Repository
public class UserDaoImpl implements UserDao {
@Autowired
private SessionFactory sessionFactory; /**
* 查询dao层接口实现类
* 进行动态拼接查询,拼接hql语句进行多条件查询
*/
public List<User> getUser(String EnID, String dateafter, String datebefore) {
String hql = "from User where 1=1";
if(EnID!=null&&!("").equals(EnID)){
hql=hql+" and EnID='"+EnID+"'";
}
if(dateafter!=null&&!("").equals(dateafter)){
hql=hql+" and datetime>='"+dateafter+"'";
}
if(datebefore!=null&&!("").equals(datebefore)){
hql=hql+" and datetime<='"+datebefore+"'";
}
Query query = sessionFactory.getCurrentSession().createQuery(hql);
List<User> list=query.list();
return list;
} }
6.service层接口
package com.tideway.springmvc.service;
import java.util.List;
import com.tideway.springmvc.entity.User;
public interface UserService {
/**
* 查询的Service层接口
* @param EnID 工号
* @param dateafter 起止日期
* @param datebefore 截至日期
* @return
*/
public List<User> getUser(String EnID,String dateafter,String datebefore);
}
7.service层接口实现类
package com.tideway.springmvc.serviceimpl; import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import com.tideway.springmvc.dao.UserDao;
import com.tideway.springmvc.entity.User;
import com.tideway.springmvc.service.UserService; @Service
public class UserServiceImpl implements UserService { @Autowired
private UserDao userDao; /**
* 查询Service层接口实现类
*/
public List<User> getUser(String EnID,String dateafter, String datebefore){
return userDao.getUser(EnID, dateafter, datebefore);
} }
8.controller层
package com.tideway.springmvc.controller; import java.util.ArrayList;
import java.util.List; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod; import com.tideway.springmvc.entity.User;
import com.tideway.springmvc.service.UserService; @Controller
public class UserController { @Autowired
private UserService userService;
/**
* 控制器
* @param EnID 工号
* @param dateafter 起止日期
* @param datebefore 截至日期
* @param model 返回的数据
* @return
*/
@RequestMapping(value="/user/getuser.do",method=RequestMethod.GET)
public String getUser(String EnID,String dateafter, String datebefore,Model model){
try {
List<User> list=new ArrayList<User>();
list=userService.getUser(EnID, dateafter, datebefore);
model.addAttribute("lists", list);
// System.out.println("list.size="+list.size());
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return "list";
} }
9.index.jsp查询条件表单提交
<body>
<form action="/SpringMVC04/user/getuser.do">
工号:<input type="text" name="EnID" />
起止日期:<input type="date"name="dateafter" />
截止日期:<input type="date"name="datebefore" />
<input type="submit" value="查询" />
</form>
</body>
10.显示查询结果页面list.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body> <table border="1" style="width: 50%">
<tr>
<th>ID</th>
<th>工号</th>
<th>名字</th>
<th>签到时间</th>
<th>操作</th>
</tr>
<c:forEach var="item" items="${lists}">
<tr>
<td>${item.id}</td>
<td>${item.enID}</td>
<td>${item.name}</td>
<td>${item.datetime}</td>
<td><a href="">编辑</a></td>
</tr>
</c:forEach>
</table>
</body>
</html>
SpringMVC整合Hibernate实现增删改查之按条件查询的更多相关文章
- JavaWeb系统(增删改查、多条件查询功能)
该系统是一个简单的青年服务管理系统,主要包括了较完整的常用的增删改查以及多条件查询功能,对于初学者有很大帮助. 下面是相关的Java代码.jsp页面.以及数据库的创建和相关表的设计 java代码 首先 ...
- PHP-----练习-------租房子-----增删改查,多条件查询
练习-------租房子-----增删改查,多条件 一 .题目要求: 二 .做法: [1]建立数据库 [2]封装类文件------DBDA.class.php <?php class DBDA ...
- springmvc+spring3+hibernate4框架简单整合,简单实现增删改查功能
转自:https://blog.csdn.net/thinkingcao/article/details/52472252 C 所用到的jar包 数据库表 数据库表就不用教大家了,一张表,很简 ...
- SpringMVC之简单的增删改查示例(SSM整合)
本篇文章主要介绍了SpringMVC之简单的增删改查示例(SSM整合),这个例子是基于SpringMVC+Spring+Mybatis实现的.有兴趣的可以了解一下. 虽然已经在做关于SpringMVC ...
- ssm框架(Spring Springmvc Mybatis框架)整合及案例增删改查
三大框架介绍 ssm框架是由Spring springmvc和Mybatis共同组成的框架.Spring和Springmvc都是spring公司开发的,因此他们之间不需要整合.也可以说是无缝整合.my ...
- SpringMVC,MyBatis商品的增删改查
一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...
- 基于SpringMVC的文件(增删改查)上传、下载、更新、删除
一.项目背景 摘要:最近一直在忙着项目的事,3个项目过去了,发现有一个共同的业务,那就是附件的处理,附件包括各种文档,当然还有图片等特殊文件,由于时间的关系,每次都是匆匆忙忙的搞定上线,称这项目的空档 ...
- EasyUI + Spring MVC + hibernate实现增删改查导入导出
(这是一个故事--) 前言 作为一个JAVA开发工程师,我觉得最基本是需要懂前端.后台以及数据库. 练习的内容很基础,包括:基本增删改查.模糊查询.分页查询.树菜单.上传下载.tab页 主管发我一个已 ...
- SpringMVC4+MyBatis3+SQLServer 2014 整合(包括增删改查分页)
前言 说起整合自然离开ssm,我本身并不太喜欢ORM,尤其是MyBatis,把SQL语句写在xml里,尤其是大SQL,可读性不高,出错也不容易排查. 开发环境 idea2016.SpringMVC4. ...
随机推荐
- java多线程面试题
很多核心Java面试题来源于多线程(Multi-Threading)和集合框架(Collections Framework),理解核心线程概念时,娴熟的实际经验是必需的.这篇文章收集了Java线程方面 ...
- wpf telerik中的book控件
下载 telerik中的书本控件,仅供学习使用.
- activity 、window与view的关系 (上)
我在研究任玉刚老师的<android开发艺术探索>的关于windowmanager那一章时,我发现自己对于acitivity.window和view之间的概念还是比较模糊. 然后查了一下a ...
- requirejs(一)
RequireJs已经流行很久了,我们在项目中也打算使用它.它提供了以下功能: 声明不同js文件之间的依赖 可以按需.并行.延时载入js库 可以让我们的代码以模块化的方式组织 初看起来并不复杂. 在h ...
- [转]webpack进阶构建项目(一)
阅读目录 1.理解webpack加载器 2.html-webpack-plugin学习 3.压缩js与css 4.理解less-loader加载器的使用 5.理解babel-loader加载器 6.理 ...
- How To Handle a Loss of Confidence in Yourself
Do you feel like you've lost confidence in yourself? Have you had strong self doubts? Perhaps you we ...
- 日志分析_使用shell完整日志分析案例
一.需求分析 1. 日志文件每天生成一份(需要将日志文件定时上传至hdfs) 2. 分析日志文件中包含的字段:访问IP,访问时间,访问URL,访问状态,访问流量 3. 现在有"昨日" ...
- 试验删除RAC(ORA10G)节点
1.环境概述 2.删除一个节点 本实验中以删除第二个节点为示例. 2.1删除数据库实例 在第一个节点上(存活的节点)上使用DBCA删除第二个节点的实例. 执行完以上操作可以看下crs_stat –t ...
- 【整理】深入理解拉格朗日乘子法(Lagrange Multiplier) 和KKT条件
在求解最优化问题中,拉格朗日乘子法(Lagrange Multiplier)和KKT(Karush Kuhn Tucker)条件是两种最常用的方法.在有等式约束时使用拉格朗日乘子法,在有不等约束时使用 ...
- JavaScript 入门教程四 语言基础【2】
一.数据类型介绍: undefined null NaN 1.判断当前变量是否为 undefined: if (i === undefined) 或者 if (typeof (i) === " ...