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的更多相关文章

  1. SSH登录与增删改查demo详解+源代码

    点击下载,测试绝对可用SSH整合框架登录加增删改查demo 下载地址:http://download.csdn.net/detail/qq_33599520/9784679   一.框架概述 spri ...

  2. 【讲义提纲】以一个实战新闻cms增删改查demo为例,给学院国创队伍培训php

    PHP实战基础——以一个新闻cms的增删改查为例 一.        环境配置 二.        数据库创建 三.        增删改查demo 连接数据库 <?php $link=mysq ...

  3. mvc模式jsp+servel+dbutils oracle基本增删改查demo

    mvc模式jsp+servel+dbutils oracle基本增删改查demo 下载地址

  4. mvc模式jsp+servel+jdbc oracle基本增删改查demo

    mvc模式jsp+servel+jdbc oracle基本增删改查demo 下载地址

  5. ssm学习(四)--完整的增删改查demo

    上一篇文章简要介绍了将sping mvc加入整个框架,算是完成了ssm的集成.本节继续前面的内容,结合spring mvc做一个简单的增删改查demo. 1.首先,重写一下GeckoList.jsp页 ...

  6. ztree--插件实现增删改查demo(完整版)

    ztree--插件实现增删改查demo(完整版) var setting = {                 async: {                     enable: true,  ...

  7. EasyUI + Spring MVC + hibernate实现增删改查导入导出

    (这是一个故事--) 前言 作为一个JAVA开发工程师,我觉得最基本是需要懂前端.后台以及数据库. 练习的内容很基础,包括:基本增删改查.模糊查询.分页查询.树菜单.上传下载.tab页 主管发我一个已 ...

  8. Hibernate全套增删改查+分页

    1.创建一个web工程 2.导入jar包 3.创建Student表 4.创建实体类 package com.entity; public class Student { private Integer ...

  9. Hibernate的增删改查

    一.搭建Hibernate开发环境,这里就不说了,直接说环境搭好后的事情. 二.项目的目录结构

随机推荐

  1. Two-phase Termination模式

    停止线程是一个目标简单而实现却不那么简单的任务.首先,Java没有提供直接的API用于停止线程.此外,停止线程时还有一些额外的细节需要考虑,如待停止的线程处于阻塞(等待锁)或者等待状态(等待其它线程) ...

  2. Codeforces Round #207 (Div. 2)

    A:超级大水题: 代码: #include<cstdio> #define maxn 105 using namespace std; int n,a[maxn],x,y,ans; int ...

  3. 【uva11374】Airport Express 最短路

    题意: 在Iokh市中,机场快线是市民从市内去机场的首选交通工具.机场快线分为经济线和商业线两种,线路,速度和价钱都不同.你有一张商业线车票,可以坐一站商业线,而其他时候只能乘坐经济线.假设换乘时间忽 ...

  4. 如何修改Ubuntu双系统的默认开机启动项

    转自:http://jingyan.baidu.com/article/ed15cb1b05d0311be369818a.html 对 于安装Ubuntu系统和windows系统(windows xp ...

  5. C++中的new/delete与operator new/operator delete

    new operator/delete operator就是new和delete操作符,而operator new/operator delete是函数. new operator(1)调用opera ...

  6. Android基础之响应Menu键弹出菜单Demo

    对于Android我也不是很熟悉,只是学习一些基本内容就OK.所以写的内容也很简单.本Demo要实现的效果就点击Menu键将弹出一个菜单并响应点击菜单项事件. 一.废话少说直接上代码.其实就是重写两个 ...

  7. Android程序安装后在模拟器上不显示,并且控制台显示The launch will only sync the application package on the device!

    初学安卓,今天写了一个小例子,可是eclipse控制台却提示 No Launcher activity found! The launch will only sync the application ...

  8. bzoj2007

    首先不难发现海拔高度只能为0或1 因为决策是单调的 不难发现最优决策一定是划分为海拔为0和1两块,不会出现01相间的情况 所以这很明显是一个最小割 由于n*n很大,我们必须要用平面图最小割转化为最短路 ...

  9. Spark PySpark数据类型的转换原理—Writable Converter

    Spark目前支持三种开发语言:Scala.Java.Python,目前我们大量使用Python来开发Spark App(Spark 1.2开始支持使用Python开发Spark Streaming ...

  10. [学习整理]eclipe/MyEclipse:重要的快捷键

    一.查看大工程代码最重要的几个快捷键 其实有一些,直接在编辑器页面内右键也可查看相应的快捷键(比如F3,F4,Ctrl+O,Ctrl+T),但有些比较好用的快捷键,并不能能直接或方便地在eclipse ...