打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
大分享-hibernate,springmvc,easyui简要介绍
近期公司一直在做项目,主要用到了springMVC,eseayui,hibernate几大框架。近一个月的时间,个人就目前自我知识给予分享。

很多公司使用mybatis产品,综合所述其最大优点是全SQL操作,灵活方便。

个人认为hibernate框架其优势比较突出。其一是因为它作为纯ORM产品,使用注解或是配置文件做好与数据表映射之后,操作实体就相当于操作数据表。而对于普通业务,多数是基于增删改操作的,较为复杂的可能就是查询操作了。实体映射关系太过于复杂容易引发牵一动百的效果,而业务逻辑中必须要这么做。那么,SQL就是最好的选择了。

  hibernate 中提供了org.hibernate.Query 接口。由 org.springframework.orm.hibernate3.support.HibernateDaoSupport.getSession() 方法返回的Sesson创建一个 

org.hibernate.Session.createSQLQuery(String arg0) throws HibernateException 方法,该方法完全以SQL方式操作数据库表,抛开了实体bean的映射。
完整代码如下:
//查找ID
public
String findTypeIdByTitle(String title) throws Exception { String sql = "select pk_id from decoration_type_info where title =:title"; Query query = this.getSession().createSQLQuery(sql); query.setString("title", title); String pkId = (String) query.uniqueResult(); return pkId; }
//更新方法public void updateTypeById(DecorationTypeInfo typeInfo) throws Exception{        String sql = "update decoration_type_info set title =:title,REMARK =:remark,UPDATE_BY =:updateBy,"                + " UPDATE_DATE = to_timestamp(to_char(sysdate,'yyyy-mm-dd hh24:mi:ss'), 'yyyy-mm-dd hh24:mi:ss:ff') "                + " where pk_id =:pkId";        Query query = this.getSession().createSQLQuery(sql);        query.setString("title", typeInfo.getTitle());        query.setString("remark", typeInfo.getRemark());        query.setString("updateBy", typeInfo.getUpdateBy());        query.setString("pkId", typeInfo.getPkId());        query.executeUpdate();    }
//删除方法public void delTypeById(String pkId)throws Exception {        String sql = " delete from unit_decoration_type_info where fk_decoration_type_id=?";        Query query = this.getSession().createSQLQuery(sql);        query.setParameter(0, pkId);        query.executeUpdate();    }
//新增方法public void addType(DecorationTypeInfo typeInfo,String themeId)throws Exception{        if (StringUtils.isBlank(typeInfo.getPkId())) {            String id = GeneratePKID.getPKID();            typeInfo.setPkId(id);        }        String sql = "insert into decoration_type_info (PK_ID,TITLE,PRICE,REMARK,FK_THEME_ID,CREATE_BY,CREATE_DATE,UPDATE_BY,UPDATE_DATE) "                + " values (?,?,?,?,?,?,to_timestamp(to_char(sysdate,'yyyy-mm-dd hh24:mi:ss'), 'yyyy-mm-dd hh24:mi:ss:ff'),"                + " ?,NULL)";        Query query = this.getSession().createSQLQuery(sql);        query.setParameter(0, typeInfo.getPkId());        query.setParameter(1, typeInfo.getTitle());        query.setParameter(2, typeInfo.getPrice());        query.setParameter(3, typeInfo.getRemark());        query.setParameter(4, themeId);        query.setParameter(5, typeInfo.getCreateBy());        query.setParameter(6, typeInfo.getUpdateBy());                query.executeUpdate();    }
//所有导入的Hibernate包import org.apache.commons.lang.StringUtils;import org.hibernate.Query;import org.hibernate.transform.Transformers;import org.springframework.stereotype.Repository;

                                         注明:以上只作为个人学习观点,不涉及任何商业或法律。

 再来说说springMVC。

个人目前理解为 :

  controller中的@Controller()和@RequestMapping("/xx/xx")注解作为action请求的唯一标志,不容许一个项目中有重复出现。

  service中的@Service("xxx1")注解作为全局唯一的service标识。

  dao中的xxxImpl类中@Repository("xx1")注解作为全局某个DAO的唯一标识。

在service服务层注入引用DAO需要@Autowired和@Qualifier("xx1")配合使用,这样便于更准确的找到引用的DAO。

controller引用service同样使用@Autowired和@Qualifier("xxx1")作为查找的条件 。

其优势总结为:AOP切面编程可以随意中任何一个类中引用其它包的资源,只要加上@Autowired自动装配注解和@Qualifier("")筛选注解即可达到一次编写,到处使用的目的。

    这样一来,我们只要编写一个通用业务处理的方法,那么中项目的任何地方都可以调用。很大程度上减轻了工作量和代码冗余量 。

//Controller段代码@Controller()@RequestMapping("/xx/xxx")public class TypeController {    @Autowired    @Qualifier("typeservice")    private TypeService typeService;        private static Log log = LogFactory.getLog(TypeController.class);    @RequestMapping("/list")    public ModelAndView bookCycleInfoList(HttpServletRequest request,            HttpServletResponse response) {        ModelAndView view = new ModelAndView();        try {            view.setViewName("/bookCycleInfo/bookCycleInfo_list");        } catch (Exception e) {            log.error("TypeController.list : " + e.getMessage());        }        return view;    }}
//Service代码@Service("typeservice")public class TypeService {    @Autowired    @Qualifier("typedao")    private TypeDao type;    public List<TreeList> queryRoomTree(String estateId) throws Exception{        try {            return bookCycleInfoDao.queryRoomTree(estateId);        } catch (Exception e) {            throw e;        }    }
//DAO中只有接口定义,本代码不做演示@Repository("typedao")public class TypeDaoImpl  {        @Override    public List findTypeList() throws Exception{        try {                        //代码体            return null;        } catch (Exception e) {            throw e;        }    }}        

                                      注明:作为初学者,该共享知识仅作为参考,不能保证完全准确性 。

 

下面说说easyUI框架 。首先,easyUI框架是完全基于JS的,个人认为它是jquery和ajax的综合体 。

其中包含很多界面控件和JS代码控制。常用的控件有datagrid,treegrid,Dialog,Menu,TextBox,NumberBox,DateTimeBox等等,ajax也非常简单,如下代码所示

<script type="text/javascript">$(function() {            var ids ="${editId}";            $.ajax({                        type : "post",                        async : false,                        url : "${pageContext.request.contextPath}/xx/xxx/findTypeById.action",                        data : {                            pkId : ids                        },                        dataType : "json",                        success : function(obj) {                            $("#pkId").textbox('setValue', obj[0].PKID);                            $("#title").textbox('setValue', obj[0].TITLE);                            $("#content").textbox('setValue', obj[0].CONTENT);                        }                    });        });</script>

    更多easyUI知识,请看官网 http://www.jeasyui.com/ 和中文网 http://www.jeasyui.net/ 。

 

 

个人感触:

     个人虽然已经有一年多的开发经验,但做的项目和写的代码为之甚少。进新公司一个月了快,虽然累,但学到了很多可用实用的东西。

所以非常开心,工作之余分享下自己的成果,既是对自我的检验,也是对雏步难行阶段学者的帮助 。

 

在编程中,所有的行动都是为了数据的存取二展开的!一条数据的生命周期随着程序的开始和结束在不断运行着,举例说明:程序是轨道,数据时列车,数据库是车站,旅客是数据源。梦想着如何改变程序的生命琐事,让它变得简洁而又实用,没有那么多繁杂的文件,这才是真正的追求 !
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
基于SSH开发架构的重新分层
SSH框架整合
DWR框架
四个月能学会Java编程吗
使用 Spring Data JPA 简化 JPA 开发
Hibernate入门
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服