SSH整合二

结构图

 articles模块

实体类Articles.java

package com.jt.articles.entity;

public class Articles {

    private Integer id;
    private String title;
    private String body;
    
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getTitle() {
        return title;
    }
    public void setTitle(String title) {
        this.title = title;
    }
    public String getBody() {
        return body;
    }
    public void setBody(String body) {
        this.body = body;
    }
    @Override
    public String toString() {
        return "Articles [id=" + id + ", title=" + title + ", body=" + body + "]";
    }    
}

 

实体类映射文件articles.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class table="t_vue_articles" name="com.jt.articles.entity.Articles">
        <id name="id" type="java.lang.Integer" column="id">
            <generator class="increment"></generator>
        </id>
        
        <property name="title" type="java.lang.String" column="title"></property>
        <property name="body" type="java.lang.String" column="body"></property>
    </class>
</hibernate-mapping>

ArticlesBiz.java

package com.jt.articles.biz;

import java.util.List;

import com.jt.articles.entity.Articles;
import com.jt.base.util.PageBean;

public interface ArticlesBiz {

     /**
     * 新增
     * @param articles
     * @return
     */
    public int add(Articles articles);
    
    /**
     * 修改
     * @param articles
     */
    public void update(Articles articles);
    
    /**
     * 删除
     * @param articles
     */
    public void del(Articles articles);
    
    /**
     * 查询
     * @param articles
     * @param pageBean
     * @return
     */
    public List<Articles> list(Articles articles,PageBean pageBean);
}

ArticlesBizImpl.java

package com.jt.articles.biz.impl;

import java.util.List;

import com.jt.articles.biz.ArticlesBiz;
import com.jt.articles.dao.ArticlesDao;
import com.jt.articles.entity.Articles;
import com.jt.base.util.PageBean;

public class ArticlesBizImpl implements ArticlesBiz{

    private ArticlesDao articlesDao;

    public ArticlesDao getArticlesDao() {
        return articlesDao;
    }

    public void setArticlesDao(ArticlesDao articlesDao) {
        this.articlesDao = articlesDao;
    }

    @Override
    public int add(Articles articles) {
        return articlesDao.add(articles);
    }

    @Override
    public void update(Articles articles) {
        articlesDao.update(articles);

    }

    @Override
    public void del(Articles articles) {
        articlesDao.del(articles);

    }

    @Override
    public List<Articles> list(Articles articles, PageBean pageBean) {
        // TODO Auto-generated method stub
        return articlesDao.list(articles, pageBean);
    }

}

ArticlesDao.java

package com.jt.articles.dao;

import java.util.List;

import org.hibernate.Session;

import com.jt.articles.entity.Articles;
import com.jt.base.dao.BaseDao;
import com.jt.base.util.PageBean;

public class ArticlesDao extends BaseDao{

    private static final long serialVersionUID = -6077790395680289782L;

    /**
     * 新增
     * @param articles
     * @return
     */
    public int add(Articles articles) {
        return (int) this.getHibernateTemplate().save(articles);
        
    }
    
    /**
     * 
     * 删除
     * @param articles
     */
    public void del(Articles articles) {
        this.getHibernateTemplate().delete(articles);
    }
    
    /**
     * 修改
     * @param articles
     */
    public void update(Articles articles) {
        this.getHibernateTemplate().update(articles);
    }
    
    /**
     * 查询
     * @param articles
     * @param pageBean
     * @return
     */
    public List<Articles> list(Articles articles, PageBean pageBean){
        Session session = this.getHibernateTemplate().getSessionFactory().openSession();
        session.beginTransaction();
        return super.executeQuery(session, "from Articles", null,pageBean);
     }    
}

ArticlesAction.java

package com.jt.articles.web;

import com.jt.articles.biz.ArticlesBiz;
import com.jt.articles.entity.Articles;
import com.jt.base.web.BaseAction;
import com.opensymphony.xwork2.ModelDriven;

public class ArticlesAction extends BaseAction implements ModelDriven<Articles>{
    
    private static final long serialVersionUID = 5943402081349505372L;
    
    private ArticlesBiz articlesBiz;
    private Articles articles =new Articles();
    
    public ArticlesBiz getArticlesBiz() {
        return articlesBiz;
    }

    public void setArticlesBiz(ArticlesBiz articlesBiz) {
        this.articlesBiz = articlesBiz;
    }
    
    /**
     * 查询
     * @return
     */
    public String list() {
        System.out.println(articlesBiz.list(articles, null));
        return null;
    }

    /**
     * 删除
     */
    public void del() {
        articlesBiz.del(articles);
    }

    /**
     * 修改
     * @return
     */
    public String update() {
        articlesBiz.update(articles);
        return null;        
    }
    
    /**
     * 新增
     * @return
     */
    public String add() {
        articlesBiz.add(articles);
        return null;
        
    }
    

    @Override
    public Articles getModel() {
        // TODO Auto-generated method stub
        return articles;
    }
}

 

User模块

User.java

package com.jt.user.entity;

public class User {

    private String uname;
    private String pwd;
    public String getUname() {
        return uname;
    }
    public void setUname(String uname) {
        this.uname = uname;
    }
    public String getPwd() {
        return pwd;
    }
    public void setPwd(String pwd) {
        this.pwd = pwd;
    }
    @Override
    public String toString() {
        return "User [uname=" + uname + ", pwd=" + pwd + "]";
    }
}

 

实体类映射文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class table="t_vue_user" name="com.jt.user.entity.User">
        
        <id name="uname" type="java.lang.String" column="uname">
            <generator class="assigned"></generator>
        </id>
        <property name="pwd" type="java.lang.String" column="pwd"></property>
    </class>
</hibernate-mapping>

UserBiz.java

package com.jt.user.biz;

import com.jt.user.entity.User;

public interface UserBiz {

    /**
     * 登录
     * @param user
     * @return
     */
    public User login(User user);
    
    /**
     * 注册
     * @param user
     * @return
     */
    public int addUser(User user);
}

UserBizImpl.java

package com.jt.user.biz.impl;

import com.jt.user.biz.UserBiz;
import com.jt.user.dao.UserDao;
import com.jt.user.entity.User;

public class UserBizImpl implements UserBiz{
    
    private UserDao userDao;
    

    public UserDao getUserDao() {
        return userDao;
    }

    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }

    @Override
    public User login(User user) {
        return userDao.login(user);
    }

    @Override
    public int addUser(User user) {
        return userDao.addUser(user);
    }
}

UserDao.java

package com.jt.user.dao;

import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.springframework.orm.hibernate5.HibernateCallback;

import com.jt.base.dao.BaseDao;
import com.jt.user.entity.User;

public class UserDao extends BaseDao{

    private static final long serialVersionUID = 3670806315799801488L;

    public User login(User user) {
        return this.getHibernateTemplate().execute(new HibernateCallback<User>() {

            @Override
            public User doInHibernate(Session session) throws HibernateException {
                return (User) session.createQuery("from User where uname= '"+user.getUname()+"' and pwd= "+user.getPwd()).list();
            }
        });
    }
    
    public int addUser(User user) {
        return (int) this.getHibernateTemplate().save(user);
    }   
}

UserAction.java

package com.jt.user.web;

import com.jt.base.web.BaseAction;
import com.jt.user.biz.UserBiz;
import com.jt.user.entity.User;
import com.opensymphony.xwork2.ModelDriven;

public class UserAction extends BaseAction implements ModelDriven<User>{
    
    private static final long serialVersionUID = 4244808665377509950L;
    
    private UserBiz userBiz;
    private User user=new User();
    
    
    public UserBiz getUserBiz() {
        return userBiz;
    }


    public void setUserBiz(UserBiz userBiz) {
        this.userBiz = userBiz;
    }

    /**
     * 登录
     * @return
     */
    public String login() {
        userBiz.login(user);
        return null;
    }
    
    /**
     * 注册
     * @return
     */
    public String addUser() {
        userBiz.addUser(user);
        return null;    
    }

    @Override
    public User getModel() {
        // TODO Auto-generated method stub
        return user;
    }
}

tree_node模块

TreeNode.java

package com.jt.tree_node.entity;

import java.util.HashSet;
import java.util.Set;

public class TreeNode {
    private Integer nodeId;
    private String nodeName;
    private Integer treeNodeType;
    private Integer position;
    private String url;
    // 关联父节点
    private TreeNode parent;
    // 关联子节点"们"
    private Set<TreeNode> children = new HashSet<TreeNode>();
    // 加载方式(1强制加载关联,0懒加载)
    private Integer initChildren = 0;

    public Integer getNodeId() {
        return nodeId;
    }

    public void setNodeId(Integer nodeId) {
        this.nodeId = nodeId;
    }

    public String getNodeName() {
        return nodeName;
    }

    public void setNodeName(String nodeName) {
        this.nodeName = nodeName;
    }

    public Integer getTreeNodeType() {
        return treeNodeType;
    }

    public void setTreeNodeType(Integer treeNodeType) {
        this.treeNodeType = treeNodeType;
    }

    public Integer getPosition() {
        return position;
    }

    public void setPosition(Integer position) {
        this.position = position;
    }

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }

    public TreeNode getParent() {
        return parent;
    }

    public void setParent(TreeNode parent) {
        this.parent = parent;
    }

    public Set<TreeNode> getChildren() {
        return children;
    }

    public void setChildren(Set<TreeNode> children) {
        this.children = children;
    }

    public Integer getInitChildren() {
        return initChildren;
    }

    public void setInitChildren(Integer initChildren) {
        this.initChildren = initChildren;
    }
}

treeNode.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class table="t_vue_tree_node" name="com.jt.tree_node.entity.TreeNode">
         <id name="nodeId" type="java.lang.Integer" column="tree_node_id">
            <generator class="increment" />
        </id>
        <property name="nodeName" type="java.lang.String"
                  column="tree_node_name">
        </property>
        <property name="treeNodeType" type="java.lang.Integer"
                  column="tree_node_type">
        </property>
        <property name="position" type="java.lang.Integer"
                  column="position">
        </property>
        <property name="url" type="java.lang.String"
                  column="url">
        </property>
        <!--
            parent定义了管理树形
            column中指定了通过那个列段来关联 对应的是当前表的主键
         -->
        <many-to-one name="parent" class="com.jt.tree_node.entity.TreeNode" column="parent_node_id"/>

        <!--
            这是定义子节点关联
         -->
        <set name="children" cascade="save-update" inverse="true">
            <!--凡是parent_node_id是当前节点的tree_node_id的就统统加入集合-->
            <key column="parent_node_id"></key>
            <one-to-many class="com.jt.tree_node.entity.TreeNode"/>
        </set>

    </class>
</hibernate-mapping>

TreeNodeBiz.java

package com.jt.tree_node.biz;

import java.util.List;

import com.jt.tree_node.entity.TreeNode;

public interface TreeNodeBiz {
     /**
     * 加载树
     * @return
     */
    public List<TreeNode> list();
}

TreeNodBizImpl.java

package com.jt.tree_node.biz.impl;

import java.util.List;

import com.jt.tree_node.biz.TreeNodeBiz;
import com.jt.tree_node.dao.TreeNodeDao;
import com.jt.tree_node.entity.TreeNode;

public class TreeNodBizImpl implements TreeNodeBiz{
    
    private TreeNodeDao treeNodeDao;
    

    public TreeNodeDao getTreeNodeDao() {
        return treeNodeDao;
    }


    public void setTreeNodeDao(TreeNodeDao treeNodeDao) {
        this.treeNodeDao = treeNodeDao;
    }


    @Override
    public List<TreeNode> list() {
        // TODO Auto-generated method stub
        return treeNodeDao.list();
    }

}

TreeNodeDao.java

package com.jt.tree_node.dao;

import java.util.List;

import org.hibernate.Hibernate;
import org.hibernate.Session;

import com.jt.base.dao.BaseDao;
import com.jt.tree_node.entity.TreeNode;

public class TreeNodeDao extends BaseDao{

    private static final long serialVersionUID = -4339387396332761044L;

    public List<TreeNode> list(){
        Session session = this.getHibernateTemplate().getSessionFactory().openSession();
        session.beginTransaction();
        //这是最好的做做法 非常好 使用 hql语句进行查询
        List<TreeNode> treeNodes =  super.executeQuery(session, "from TreeNode where treeNodeType = 1", null,null);
        //进行强子加载子节点
        if (treeNodes != null && treeNodes.size() > 0) {
            for (TreeNode t : treeNodes) {
                //强制加载子节点
                Hibernate.initialize(t.getChildren());
            }
        }
        return treeNodes;
    }
}

TreeNodeAction.java

package com.jt.tree_node.web;

import java.util.List;

import com.jt.base.web.BaseAction;
import com.jt.tree_node.biz.TreeNodeBiz;
import com.jt.tree_node.entity.TreeNode;

public class TreeNodeAction extends BaseAction{

    private static final long serialVersionUID = -6038611615430719428L;
    
    private TreeNodeBiz treeNodeBiz;
    
    
    public TreeNodeBiz getTreeNodeBiz() {
        return treeNodeBiz;
    }


    public void setTreeNodeBiz(TreeNodeBiz treeNodeBiz) {
        this.treeNodeBiz = treeNodeBiz;
    }

    public String list() {
         List<TreeNode> list = treeNodeBiz.list();
         System.out.println("我是长度" + list.size());
         TreeNode node = list.get(0);
         System.out.println(node);
         System.out.println(node.getChildren());
         for (TreeNode n: node.getChildren()) {
             System.out.println("我是子节点:" + n.getNodeName());
         }
        return null;    
    }    
}

 

posted @ 2019-08-18 22:18  youshutup  阅读(168)  评论(0编辑  收藏  举报