这样修改应该是有问题的,比如在:
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"); } }
暂时测试没有问题。