这样修改应该是有问题的,比如在:
User u = new User();
Org o = new Org();
比如Org.find
下会有问题,不知道在不去掉Model中的静态方法的情况下,有什么更好的办法?
----------------------
ActiveJDBC很不错,轻量级,而且API设计的比较简洁。但是每次都需要instrument,虽然提供了ANT的命令,但感觉还是很烦。
修改一下:
在Model中增加一个变量:
private final static ThreadLocal<String> clna = new ThreadLocal<String>();
增加一个构造函数:
protected Model(String className) {
this();
clna.remove();
clna.set(className);
}
然后将Model.getClassName()方法修改为:
private static String getClassName() {
// return new ClassGetter().getClassName();
return clna.get();
}
这样就可以了。在子类中调用:
public class Employee extends Model {
// static {
// validatePresenceOf("first_name", "last_name");
// }
public Employee(){
super("activejdbc.ant.example.Employee");
validatePresenceOf("first_name", "last_name");
}
}
暂时测试没有问题。