hibernate之增删改查demo
package dao; import java.util.ArrayList;
import java.util.List; import org.hibernate.Query;
import org.hibernate.SQLQuery;
import org.hibernate.Transaction; import com.sun.org.apache.bcel.internal.generic.GETSTATIC; import common.BaseDAO;
import common.DataZh; import entity.Station; //station和ddxx是一对多关系,为保证代码整洁,每个实体的增删改查写在自己的dao,复杂查询可以写在需要的dao里
public class StationDAO extends BaseDAO<Station> { ////////////////////////////////////////////////////////////////演示hql查询
// 使用Hql查询站名里含"京"字的所有站点
public List findByproperty(String propertyName) { // 通过占位符传参
String querystring = "from Station as model where model.czmc like ?"; // 显示传参
// String
// querystring="from Station as model where model.czmc like '%"+propertyName+"%'"; Query queryObject = gs().createQuery(querystring); queryObject.setParameter(0, "%" + propertyName + "%"); // 传参 return queryObject.list();
} // 查询最后一个字是"京"字并且等级是"一级的"所有站点
public List findByKey(String Key1, String Key2) { String querystring = "from Station as model where model.czmc like ? and model.dj=?"; // 显示传参
// String
// querystring="from Station as model where model.czmc like '%"+propertyName+"%'"; Query queryObject = gs().createQuery(querystring); queryObject.setParameter(0, "%" + Key1);
queryObject.setParameter(1, Key2); // 传参 return queryObject.list();
} // 通过判断参数动态组合Hql语句,生成基本通用查询
public List find(Station entity) {
List reuslt = null; // 字符串辅助类
StringBuffer hql = new StringBuffer("from Station where 1=1"); List vp = new ArrayList(); if (entity != null) { // 小于0的和null都不做比较
if (entity.getCzdm() != null && entity.getCzdm() < 0) {
hql.append(" and czdm=?");
vp.add(entity.getCzdm());
} // 空字符串和null都不做比较
if (entity.getCzmc() != null && entity.getCzmc().length() > 0) {
hql.append(" and czmc = ?");
vp.add(entity.getCzmc());
} if (entity.getDj() != null) {
hql.append(" and dj=?");
vp.add(entity.getDj());
}
} Query q = gs().createQuery(hql.toString()); for (int i = 0; i < vp.size(); i++) {
q.setParameter(i, vp.get(i));
} reuslt = q.list();
return reuslt;
} ////////////////////////////////////////////////////////////////演示复杂查询 // 使用原生sql,根据等级模糊查询符合条件的所有车站名
public List<String> findonebydj(String dj) {
// sql语句
String sql = "select czmc from station where dj like '%" + dj + "%'"; SQLQuery q = gs().createSQLQuery(sql); return DataZh.ObjtoStr(q.list());
} // 使用原生sql,根据等级模糊查询符合条件的所有的车站名和车站代码
public List<String[]> findmanybydj(String dj) {
// sql语句
String sql = "select czmc,czdm from station where dj like '%" + dj
+ "%'"; SQLQuery q = gs().createSQLQuery(sql); return DataZh.ObjArrtoStrArr(q.list());
} // 使用原生sql,关联两表station,ddxx, 查询广州东发出的所有订单id,状态,等级
public List<String[]> findmanysbydj(String dj) {
// sql语句
String sql = "select a.czmc,id,b.status,dj from station a,ddxx b where a.czdm=b.czid and a.czmc='"
+ dj + "'"; SQLQuery q = gs().createSQLQuery(sql);
return DataZh.ObjArrtoStrArr(q.list());
} ////////////////////////////////////////////////////////////////演示复杂删除 // 输入车站代码,将相关的车站和订单全部删除
public int excuteFzDelete(Integer id) { //分别删除
String sql = "delete from station where czdm=" + id;
String sql2 = "delete from ddxx where czid=" + id; // 增删改需要事务,事务开始
Transaction tx = null;
tx = gs().beginTransaction(); SQLQuery q = gs().createSQLQuery(sql); int a = q.executeUpdate(); SQLQuery q2 = gs().createSQLQuery(sql2);
int b = q2.executeUpdate(); tx.commit(); // 提交事务 if (a > 0 || b > 0) //有效删除则返回1
return 1;
else
return 0; //无效删除则返回0 } ////////////////////////////////////////////////////////////////演示复杂更新 // 将所有无效的(车站已经不存在的)订单全部车站ID(czid)全部更新为指定的车站ID //复杂更新,需用inner join
//update ddxx a INNER JOIN
//(select id from ddxx where czid not in(select DISTINCT czdm from station)) as b
//ON a.id=b.id set czid=222
public int excuteFzUpdate(Integer czid)
{
StringBuffer s=new StringBuffer();
s.append("update ddxx a INNER JOIN");
s.append("(select id from ddxx where czid not in(select DISTINCT czdm from station)) as b");
s.append(" ON a.id=b.id set czid="+czid); //增删改加事务
Transaction tx;
tx=gs().beginTransaction();
SQLQuery q=gs().createSQLQuery(s.toString()); //受影响的行数
int a=q.executeUpdate();
tx.commit();
return a;
} ////////////////////////////////////////////////////////////////演示多对多 /*
* 站点(Station)与线路(Line)是多对多关系,
* 在数据库里面,解决方式是拆成三张表,做一个中间表,中间表要包含两个主表的主键
* 多对多拆成了两个一对多
*
*/ //查询经过指定站点的所有线路名称
public List<String> searchLineByStation(String czmc)
{
String sql = "select xlmc from line where xlid in (select a.LID from stationjoinline a,station b where a.SID = b.czdm and b.czmc=?)";
SQLQuery q=gs().createSQLQuery(sql); //建议使用setParameter加参数
q.setParameter(0, czmc);
return DataZh.ObjtoStr(q.list());
} //查询指定线路经过的所有站点名称,站点ID
public List<String[]> searchStationByLine(String xlmc)
{
String sql="SELECT * from station c WHERE c.czdm IN"+
"(SELECT b.SID FROM stationjoinline b WHERE b.LID IN"+
"(SELECT a.xlid FROM line a WHERE a.xlmc=?))";
SQLQuery q=gs().createSQLQuery(sql);
q.setParameter(0, xlmc);
List<String[]> list=q.list();
return DataZh.ObjArrtoStrArr(q.list());
} ////////////////////////////////////////////////////////////dao总结
/*
* 总结:
*
* --------------------------------------查询
* 1.hql查询
*
* StringBuffer hql = new StringBuffer("from Station where 1=1");
*
* Query q = gs().createQuery(hql.toString());
*
* q.list();
*
* 2.sql查询
*
* String sql = "select czmc,czdm from station where dj like '%" + dj
+ "%'"; SQLQuery q = gs().createSQLQuery(sql); //sql查询使用createSQLQuery q.list();
*
* DataZh.ObjArrtoStrArr(q.list()) //sql查询返回的是Object,记得转换
*
*
* --------------------------------------增删改
* 使用原生sql语句执行
*
* String sql = "delete from station where czdm=" + id;
*
* Transaction tx = null;
tx = gs().beginTransaction(); SQLQuery q = gs().createSQLQuery(sql); * tx.commit(); // 提交事务
*
* q.executeUpdate() //增删改的语句使用这个函数
*
* return result //返回受影响的行数
*
*/ }
hibernate之增删改查demo的更多相关文章
- SSH登录与增删改查demo详解+源代码
点击下载,测试绝对可用SSH整合框架登录加增删改查demo 下载地址:http://download.csdn.net/detail/qq_33599520/9784679 一.框架概述 spri ...
- 【讲义提纲】以一个实战新闻cms增删改查demo为例,给学院国创队伍培训php
PHP实战基础——以一个新闻cms的增删改查为例 一. 环境配置 二. 数据库创建 三. 增删改查demo 连接数据库 <?php $link=mysq ...
- mvc模式jsp+servel+dbutils oracle基本增删改查demo
mvc模式jsp+servel+dbutils oracle基本增删改查demo 下载地址
- mvc模式jsp+servel+jdbc oracle基本增删改查demo
mvc模式jsp+servel+jdbc oracle基本增删改查demo 下载地址
- ssm学习(四)--完整的增删改查demo
上一篇文章简要介绍了将sping mvc加入整个框架,算是完成了ssm的集成.本节继续前面的内容,结合spring mvc做一个简单的增删改查demo. 1.首先,重写一下GeckoList.jsp页 ...
- ztree--插件实现增删改查demo(完整版)
ztree--插件实现增删改查demo(完整版) var setting = { async: { enable: true, ...
- EasyUI + Spring MVC + hibernate实现增删改查导入导出
(这是一个故事--) 前言 作为一个JAVA开发工程师,我觉得最基本是需要懂前端.后台以及数据库. 练习的内容很基础,包括:基本增删改查.模糊查询.分页查询.树菜单.上传下载.tab页 主管发我一个已 ...
- Hibernate全套增删改查+分页
1.创建一个web工程 2.导入jar包 3.创建Student表 4.创建实体类 package com.entity; public class Student { private Integer ...
- Hibernate的增删改查
一.搭建Hibernate开发环境,这里就不说了,直接说环境搭好后的事情. 二.项目的目录结构
随机推荐
- 纯CSS实现delay连续动画
从前css3还没出来的时候,用jquery的delay方法可以串起一个一个独立的动画片段. 那么在不使用jquery的平台上,如何借助css3来完成一些列动作呢? 有高人做了一个动感十足的人物动画: ...
- 待解决)leetcode 路径和 dfs 线序遍历
Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the given su ...
- 爬虫技术实战 | WooYun知识库
爬虫技术实战 | WooYun知识库 爬虫技术实战 大数据分析与机器学习领域Python兵器谱-大数据邦-微头条(wtoutiao.com) 大数据分析与机器学习领域Python兵器谱
- 关于python写GUI桌面应用的一些研究结果
研究了一下python开发GUI桌面应用的解决方案,研究结果记录如下: EasyGui:控件极为简单,连个基本的grid.list组件都没有,不适合商用,甚至是普通的应用都不行,放弃! Tkinter ...
- SpringMVC ModelAndView方法与模板传参接收不到问题
最近在使用Spring MVC做项目时,碰到一个问题,就是通过ModelAndView与前端模板页面通信时,一直无法在模板中显示出来传过去的参数值. 在网上也查了好久,就是不知道是啥问题,很是郁闷. ...
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码]
原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(32)-swfupload多文件上传[附源码] 文件上传这东西说到底有时候很痛,原来的asp.net服务器 ...
- JAVA 内存泄露的理解
1 什么是内存泄露? 内存泄露是指没用的对象持续占有内存空间,造成内存空间浪费.所以说JAVA是有内存泄露的. 2 内存泄露的原因是什么? 较长生命周期对象持有短生命周期对象的引用,导致短生命周期对象 ...
- Node.js小Httpserver
须要说明两点: 1 程序文件hello.js需用记事本另存为utf-8格式的hello.js watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamVhcGVk ...
- android自定义控件,动态设置Button的样式
原文 http://www.cnblogs.com/landptf/p/4562203.html 今天来看一个通过重写Button来动态实现一些效果,如圆角矩形.圆形.按下改变字体,改变背景色,改变 ...
- systemtap [主设备号,次设备好,inode]监控文件
SystemTap 是监控和跟踪运行中的linux 内核的操作的动态方法,SystemTap 应用:对管理员,SystemTap可用于监控系统性能,找出系统瓶颈,而对于开发者,可以查看他们的程序运行时 ...