NutzCN Logo
分享 nutz-sqltpl插件,类似mybatis管理sql
发布于 2119天前 作者 threefish 3548 次浏览 复制 上一个帖子 下一个帖子
标签:

源码 https://github.com/threefish/nutz-sqltpl

nutz-sqltpl SQL模板实现

支持多种模板引擎

默认采用beetl引擎(注意,这不是与BeetlSql的集成),其他模版引擎可以自己扩展,详情看源码

用法

然后在pom.xml中
```xml

com.github.threefish
nutz-sqltpl
1.3.RELEASE

然后在ioc.js中

var ioc = {
sqlTplIocEventListener: {
type: "com.github.threefish.nutz.sqltpl.SqlTplIocEventListener",
args: [{refer: '$ioc'}]
},
beetlSqlTemplteEngineImpl: {
type: "com.github.threefish.nutz.sqltpl.BeetlSqlTemplteEngineImpl",
events: {
create: "init"
},
fields: {
statementStart : "[#",//可修改
statementEnd :"#]"//可修改
}
}
}
}
```

然后,在MainSetup.init内加入下面的语句, 启用热加载(注意:JAR包中的xml无法进行热加载)

SqlsTplHolder.DEVELOPER_MODE = true;

然后,你需要一个Service文件 实现 ISqlDaoExecuteService 接口

@IocBean(args = {"refer:dao"}, name = "companyService")
@SqlsXml("CompanyService.xml")
public class CompanyServiceImpl extends BaseServiceImpl<Company> implements CompanyService, ISqlDaoExecuteService {
    /**
    * 1、我是必须要有的
    * 2、可以不实现 ISqlDaoExecuteService 接口,用 SqlsTplHolder 直接渲染sql自己再进行操作
    */
    private SqlsTplHolder sqlsTplHolder;

    public CompanyServiceImpl(Dao dao) {
        super(dao);
    }

    @Override
    public SqlsTplHolder getSqlsTplHolder() {
        return this.sqlsTplHolder;
    }

    @Override
    public Dao getDao() {
        return dao;
    }

    @Override
    public Entity getEntity() {
        return super.getEntity();
    }

    @Override
    public Class getEntityClass() {
        return super.getEntityClass();
    }
    /**
     *  分页查询列表
     * @param param
     * @param pager
     * @return 
     */
    @Override
    public List<NutMap> queryAllBySql(NutMap param, Pager pager) {
        //此处queryAll对应
        return queryMapBySql("queryAll", param);
    }
}


你需要一个XML文件来管理当前service的Sql(请把我和CompanyServiceImpl放在一起,或采用相对路径自己摸索)

当模版语法 [# if()... for()...等等 #] 取值表达式 ${}

来看一下例子
```xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE Sqls SYSTEM "nutzfw-sqls.dtd">


logistics_company
<![CDATA[
SELECT * from ${tableName}
[# if(isNotEmpty(name)){ #]
where name like @name
[#}#]
]]>

```

1 回复

按照这个方法配置sqlsTplHolder为null是怎么回事?

添加回复
请先登陆
回到顶部