nutz 自定义sql的使用
虽然提供了Cnd,但是用起来是觉得有点不方便,然后就直接编写Sql语句。nutz提供了一些方法。

- Nutz.Dao 的自定义 SQL 部分的解决方案是:
// 不推荐使用- 用户可以硬编码 SQL 语句,比如:
- Sql sql = Sqls.create("DELETE FROM t_abc WHERE name='Peter'");
- // 可以。防注入。不过太多字符串了,要拼接。
- 支持占位符的书写方式,比如:
- Sql sql = Sqls.create("DELETE FROM $table WHERE name=@name");
- sql.vars().set("table","t_abc");
- sql.params().set("name","Peter");
- $table 将会被替换成 t_abc
- @name 将会被替换成 ?,用来创建 PreparedStatement
- // 这种方法不错,代码显得好看点,而且,方便CV操作
- 用户可以将所有的 SQL 语句存放在一个或者多个文件中,语句的间隔可以通过注释,比如:
- /* delete.data */
- DELETE FROM $table WHERE name LIKE @name
- /* update.data */
- UPDATE FROM $table SET name=@name WHERE id=@id
- 在你的 Java 代码中:
- Sql sql = dao.sqls().create("delete.data");
- 你可以为你的 SQL 任意定制回调,后面会有详细讲解

根据nutz的文档,最终主要采用将sql语句放置在多个文件中来管理的方法比较容易管理代码。
使用方法如下,初始化时,让dao载入.sqls文件。有两种方法。
第一种,构造时加载。路径你也可以用文件夹,这样会加载文件夹下所有.sqls文件
- Dao dao = new NutDao(datasource,new FileSqlManager("demo/sqls/all.sqls"));
- System.out.println(dao.sqls().count());
或者在dao.js写好,用ioc加载

- var ioc = {
- conf : {
- ...
- },
- dataSource : {
- ...
- },
- sqlSource:{
- type:"org.nutz.dao.impl.FileSqlManager",
- args:["sql"]
- },
- dao : {
- type : "org.nutz.dao.impl.NutDao",
- args : [{refer:"dataSource"},{refer:"sqlSource"}]
- }
- };

第二种,在构造后加载
- Dao dao = new NutDao(datasource);
- ((NutDao)dao).setSqlManager(new FileSqlManager("demo/sqls/all.sqls"));
- System.out.println(dao.sqls().count());
PS:.sqls 文件必须是 UTF-8编码
------------------------------------------------------------------------------------------------------------------------------------------------------------------------
好了,前期工作完成。该弄弄怎么使用了。首先,写好你自己的.sqls文件。
1.通过 dao.sqls().create(""); 加载对应的sql语句。
2.替换相应的占位符。
3.设置回调函数,回调函数中,通过 invoke 函数你进行后续操作。
4.执行dao.execute(sql)。这里是同步,会等待结束,直至失败,或者回调函数执行完毕才会继续执行。

- @At
- @Ok("jsp:jsp.test.getMenuDi")
- public void getMenuByIoc(HttpSession session)
- {
- Sql sql = dao.sqls().create("getMenu.data");
- sql.params().set("id", 1);
- sql.setCallback(new SqlCallback() {
- public Object invoke(Connection conn, ResultSet rs, Sql sql) throws SQLException {
- .....
- while (rs.next()){
- ....
- m.setName(rs.getString("menu_name"));
- ....
- }
- System.out.println("callback end");
- return myMenu;
- }
- });
- dao.execute(sql);
- System.out.println("execute end");
- MyMenu myMenu = sql.getObject(MyMenu.class);
- ...
- }

然后,就可以开始继续写代码了。
nutz 自定义sql的使用的更多相关文章
- phpcmsv9自定义sql语句查询模型实现
在phpcmsv9中,自定义sql语句查询可不太好实现,传入sql语句查询很容易被内部转入生成一系列莫名其妙的sql语句,比如最佳前缀等等,直接造成sql语句查询错误,在此也提供两种解决办法,1修改底 ...
- thinkjs中自定义sql语句
一直以为在使用thinkjs时,只能是它自带的sql语句查询,当遇到类似于这样的sql语句时,却不知道这该怎样来写程序,殊不知原来thinkjs可以执行自定义sql语句 SELECT * from a ...
- 11月16日《奥威Power-BI基于SQL的存储过程及自定义SQL脚本制作报表》腾讯课堂开课啦
上周的课程<奥威Power-BI vs微软Power BI>带同学们全面认识了两个Power-BI的使用情况,同学们已经迫不及待想知道这周的学习内容了吧!这周的课程关键词—— ...
- django不定义model,直接执行自定义SQL
如果不想定义model,直接执行自定义SQL,可如下操作: 1. 通过 connections获取db连接,如果是多个数据库,connections['dbName'] 来选择 2. 获取游标 cur ...
- Python Django 之 直接执行自定义SQL语句(二)
转载自:https://my.oschina.net/liuyuantao/blog/712189 一般来说,最好用 Django 自带的模型来实现这些操作.这里仅仅只是为了学习使用原始 SQL 而做 ...
- Python Django 之 直接执行自定义SQL语句(一)
一.执行自定义SQL方法 1.Executing custom SQL directly 直接执行自定义SQL,这种方式可以完全避免数据模型,而是直接执行原始的SQL语句. 2.Manage ...
- 【JEECG技术文档】数据权限自定义SQL表达式用法说明
功能介绍 数据规则通过配置自定义sql来实现数据权限的控制,自定义SQL支持表达式取值 其中自定义sql 条件中字段的名称和数据库表的字段名保持一致. 角色授权 用户角色授权,权限测试不要用adm ...
- SpringBoot Mybatis 执行自定义SQL
1.XML中执行自定义SQL. https://blog.csdn.net/u012427355/article/details/80654806 2.注解执行自定义SQL @Select(" ...
- spring-jpa通过自定义sql执行修改碰到的问题
在编写自定义SQL的时候需要注意 @Query 注解只能用来查询,想要进行添加.修改和删除操作需要配合 @Modifying 注解一同使用 @Modifying @Query("update ...
随机推荐
- UNIX C 信号
1.信号处理 #include <signal.h> typedef void(*sighander_t)(int); sighander_t signal(int signum,sigh ...
- Git 基础教程 之 删除文件
① 手动或命令 rm删除工作区的问价: git checkout -- readme.txt 可恢复 checkout 实际上是用版本库里的替换工作区的版本 ② 删除了工作区文 ...
- 1.3 eclipse中配置Tomcat
下载并成功安装Eclipse和Tomcat(): 打开Eclipse,单击“window”菜单,选择下方的“Preferences”: 步骤阅读 3 找到Server下方的Runtime Envi ...
- HDU 1466
经典DP,这样的递推确实有点难. 把所有直线分成两组,可以知道 m条直线的交点方案数 =(m-r)条平行线与r条直线交叉的交点数 + r条直线本身的交点方案 亦就是 =(m-r)*r+r条之间本身 ...
- boost中的有用工具assign和uuid
assign assign重载'+'=和','实现连续赋值 assign不仅支持所有8个STL标准容器(vector.string.deque.list.set.multiset.map.multim ...
- 【小超_Android】android上开源的酷炫的交互动画和视觉效果:Interactive-animation
1.交互篇 2.视觉篇 交互篇 1.SlidingUpPanelLayout 项目介绍:他的库提供了一种简单的方式来加入一个可拖动滑动面板(由谷歌音乐推广,谷歌地图和Rdio)你的Android应用程 ...
- int*与(int*)的差别
晚上被问到一个C++的问题: int **pa=new int* [5]; int *pb=new (int*)[5]; 上面两行代码的差别是什么? 分析与实验结果例如以下: (1)第一行代码能够在V ...
- 基于spark1.4的Spark-Sql
Author: kwu 基于spark1.4的Spark-Sql,spark1.4.1在7月15刚公布.提供较好sql支持 1.怎样启动Spark-Sql 启动脚本例如以下 #!/usr/bin/en ...
- YII用户注冊和用户登录(三)之模型中规则制定和分析
3 模型中规则制定和分析 YII模型主要分为两类,一个数据模型,处理和数据库相关的增删改查.继承CActiveRecord.还有一个是表单模型,继承CFormModel.不与数据库进行交互.操作与数据 ...
- Kaggle之泰坦尼克号幸存预测估计
上次已经讲了怎么下载数据,这次就不说废话了,直接开始.首先导入相应的模块,然后检视一下数据情况.对数据有一个大致的了解之后,开始进行下一步操作. 一.分析数据 1.Survived 的情况 train ...