下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

spring的极简封装:springrain

作者:课课家教育     来源: http://www.kokojia.com点击数:932发布时间: 2016-01-26 16:41:30

标签: Java控件springJava插件

大神带你学编程,欢迎选课

  springrain本身就是一个完整的ecliPSe项目,spring一站式开发的范例,包含spring core,spring JDBC,spring mvc.可以认为就是一个spring的demo.

spring的极简封装 springrain_Java控件_spring_Java插件_课课家

  springrain 自带一个代码生成器,能够生成对表的增删改查的逻辑代码,以及前台页面样式和js文件

  spring良好的扩展性,集成度,IOC,AOP事务,已经是项目的基础条件.

  项目只依赖spring,没有hibernate,struts,ibatis.

  使用shiro权限控制到按钮级

  结合shiro,Redis实现了天然的分布式session共享

  hibernate太过复杂,运用不好就会造成很大影响,ibatis的优势就是把sql写入XML文件,利于数据库调优和sql语句管理.数据库调优可以使用druid直接输出比较慢的sql,比分析xml中的语句更直观,关于sql管理,springrain所有的sql语句都使用Finder封装,只要查看Finder在项目中的引用,就能查看项目中所有的sql语句,就此,ibatis的优势就很小了.

  struts 和 spring mvc 相比,个人感觉还是有点差距的.

  一些测试案例:

  52//就极简而言,一个数据库只需要一个Service,就可以管理这个数据库的任意一张表

  //@Test 查询基本类型

  public void testObject() throws Exception{

  // Finder finder=new Finder("select id from t_user where 1=1 ");

  Finder finder=Finder.getSelectFinder(User.class,"id").append(" WHERE 1=1 ");

  finder.append("and id=:userId").setParam("userId", "admin");

  String id = baseDemoService.queryForObject(finder, String.class);

  System.out.println(id);

  }

  //@Test 查询一个对象

  public void testObjectUser() throws Exception{

  //Finder finder=new Finder("select * from t_user where id=:userId order by id");

  Finder finder=Finder.getSelectFinder(User.class).append(" WHERE id=:userId order by id desc ");

  finder.setParam("userId", "admin");

  User u = baseDemoService.queryForObject(finder, User.class);

  System.out.println(u.getName());

  }

  //@Test 查询分页

  public void testMsSql() throws Exception{

  //Finder finder=new Finder("select * from t_user order by id");

  Finder finder=Finder.getSelectFinder(User.class).append(" order by id desc ");

  Listlist = baseDemoService.queryForList(finder, User.class, new Page(2));

  System.out.println(list.size());

  for(User s:list){

  System.out.println(s.getName());

  //@Test 调用数据库存储过程

  public void testProc() throws Exception{

  Finder finder=new Finder();

  finder.setParam("unitId", 0);

  finder.setProcName("proc_up");

  Map queryObjectByProc = (Map) baseDemoService.queryObjectByProc(finder);

  System.out.println(queryObjectByProc.get("#update-count-10"));

  //@Test 调用数据库函数

  public void testFunction() throws Exception{

  Finder finder=new Finder();

  finder.setFunName("fun_userId");

  finder.setParam("userId", "admin");

  String userName= baseDemoService.queryForObjectByByFunction(finder,String.class);

  System.out.println(userName);

赞(11)
踩(4)
分享到:
华为认证网络工程师 HCIE直播课视频教程