2019-04-30 18:17

你自己画的红框,仔细看一下,里头并没有使用 MAIN_CLASS 来识别当前要关闭的项目,而是用的 APP_BASE_PATH 变量,该变量对于每一个项目都是唯一的

该变量是你当前项目的根目录,两个不同的项目不可能拥有同一个根目录

2019-04-30 17:35

没想到还真能动态创建 database,自此建库、建表、建字段、改字段,完全动态化了,超赞

2019-04-30 17:33

第一次见这么玩 enjoy sql 模板的,有创新精神,期待开源

2019-04-30 14:51

Model 用的是 active record 模式,而 active record 模式的核心是一个 model 对象唯一对应一个 table 中的一条记录,而这个对应关系是通过主键来完成的

如果你没有主键,那么 active record 模式的前提假设就不成立,所以就没有了所谓的生成 Model 这件事存在了

table 没有主键并非好习惯,在没有主键的情况下可以使用 jfinal 的 Db + Record 模式

2019-04-30 12:08

@qyq1103 maven 项目直接下载 jfinal demo for maven ,里头有 pom.xml

maven 项目不需要 jar 包,会自动化下载

2019-04-30 11:13

如果不希望对外界响应任何数据,使用:
renderNull();

2019-04-30 11:12

WxController 的 wx() 是 action, 是外部触发的,那么你希望对外界响应一个什么数据?

例如可以:
renderJson("msg", "成功");

2019-04-30 11:11

一般是动态建表:
Db.update("create table ....");

动态建 database 还真没玩过,试试这样:
Db.update("create database ....");

传 sql 进去即可

动态建库应该要先建立连接,多试验

2019-04-30 11:08

@qyq1103 总之,全用 jfinal-3.8-all.zip 中的 jar 包,其中的作用里头有一个说明文件

你自己找的 jar 包就要保证其版本合适

2019-04-30 11:07

@crazykids find 方法本身是极快的,因为 jfinal 的任何数据库操作方法都是对 JDBC 的极薄封装

慢就慢在,如果你返回的数据条数多的话,io 动作就慢了, io 动作本身就与 jfinal 无关了

我这边不仅要用聚合函数,也得查表中的一部分字段,用 find 是可以的

也可以试试 Db.query 方法,该方法返回的值不封装为 Model、Record,是原生的 java 对象,能提点速度,但这个提速基本可以忽略不计

2019-04-30 09:55

find 会获取数据,有 io 开销,带有 sum、count 的,可以缩减 select 后面的字段,例如:
select * 改成
select x

再有,如果只是为了获取聚合函数的值,可以用:
Db.queryInt("select count(*) from t where ...", p1, p2, ...p3);

不要用 find,find 用于将查询的值封装成 model

2019-04-30 09:55

find 会获取数据,有 io 开销,带有 sum、count 的,可以缩减 select 后面的字段,例如:
select * 改成
select x

再有,如果只是为了获取聚合函数的值,可以用:
Db.queryInt("select count(*) from t where ...", p1, p2, ...p3);

不要用 find

2019-04-30 09:53

@qyq1103 注意 jetty-server 也用那个 zip 中的,现在的版本到了 jetty-server-2019.3

2019-04-30 09:05

非 maven 版项目,下载首页右侧的 jfinal-3.8-all.zip, 全部使用里面提供的 jar 包

你自己找的 jar 就要确保完备可用,版本要对,最好不要自己找

2019-04-29 17:51

@zeroabc 4.0 版本上了以后,即便不改代码也可以的, remove 再 add 这个不影响 jfinal 4.0 中配置的优先级,有兴趣可以看一下 FieldKit.java 源码