herbnate session.createSQLQuery(sql) 和 session.createQuery(sql)使用

简介:
public class DistributeDao implements Serializable{
    private SessionFactory sessionFactory;  
    
    public Session getSession() {  
        return sessionFactory.getCurrentSession();  
    }  
  
    public SessionFactory getSessionFactory() {  
        return sessionFactory;  
    }  
  
    public void setSessionFactory(SessionFactory sessionFactory) {  
        this.sessionFactory = sessionFactory;  
    }  
    
    public Task getTask(Integer id) {
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        List<Task> datas = session.createQuery("from  TestMessage").list();//TestMessage是一个java类,这个类和某一个表对应!
        tran.commit();
        return datas.get(id);
    }

    public void saveTask(Task task) {
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        session.save(task); 
        tran.commit();
    }

    public List<Task> findAllTask() {
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        List<Task> datas = session.createQuery("from Task").list();
        tran.commit();
        return datas;
    }
    
    public List<Task> findAllFinishedTask() {
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        List<Task> datas = session.createQuery("from Task where state=2").list();
        tran.commit();
        return datas;
    }
    
    public List<Task> findUserTaskFinish(String developName){
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        String sql="select * from task where task.taskid in (select taskteam.taskid from taskteam where taskteam.developName=\'" + developName + "\') and task.state=2";
        List<Task> datas = (List<Task>)session.createSQLQuery(sql).addEntity(Task.class).list();
        tran.commit();
        return datas;
    }
    
    public List<Task> findUserTaskNoParticipateTask(String developName){
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        String sql="select * from task where task.taskid not in (select taskteam.taskid from taskteam where developName=\'" + developName + "\')";
        List<Task> datas = (List<Task>)session.createSQLQuery(sql).addEntity(Task.class).list();//必须有addEntity()方法,否则不能
                                                           //返回具体的类型,其实返回的是Object
        tran.commit();
        return datas;
    }
    
    public List<Task> findUserTaskParticipating(String developName){
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        String sql="select * from task where task.taskid in (select taskteam.taskid from taskteam where developName=\'" + developName + "\') and task.state=1";
        List<Task> datas = (List<Task>)session.createSQLQuery(sql).addEntity(Task.class).list();
        tran.commit();
        return datas;
    }
    
    public List<DevelopingParty> findTaskAllUser(int taskid){
        Session session = this.getSession();
        Transaction tran = session.beginTransaction();
        String sql="select * from developingparty where developingparty.developName in (select taskteam.developingparty from taskteam where taskteam.taskid=" + taskid + ")";
        List<DevelopingParty> datas = session.createSQLQuery(sql).addEntity(DevelopingParty.class).list();
        tran.commit();
        return datas;
    }
}








本文转自 小眼儿 博客园博客,原文链接:http://www.cnblogs.com/hujunzheng/p/4587330.html,如需转载请自行联系原作者
目录
相关文章
|
5天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
40 10
|
1月前
|
SQL 数据库 数据安全/隐私保护
Sql Server数据库Sa密码如何修改
Sql Server数据库Sa密码如何修改
|
2月前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之数据查询
【数据库SQL server】关系数据库标准语言SQL之数据查询
95 0
|
2月前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之视图
【数据库SQL server】关系数据库标准语言SQL之视图
72 0
|
2月前
|
SQL 人工智能 算法
【数据库SQL server】传统运算符与专门运算符
【数据库SQL server】传统运算符与专门运算符
68 0
|
15天前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
15 0
|
5天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
55 6
|
5天前
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
|
9天前
|
SQL 安全 Java
SQL server 2017安装教程
SQL server 2017安装教程
13 1
|
22天前
|
SQL 存储 Python
Microsoft SQL Server 编写汉字转拼音函数
Microsoft SQL Server 编写汉字转拼音函数