问题:
在某信誉度评估系统中,客户的信誉度是由与客户相关的信息根据一定算法综合评定产生的。假如根据用户贷款以及还款情况评定,按照面向对象方法,将有客户类、贷款类、还款类。客户类要使用链表等表示客户与贷款,还款之间的一对多关系,评定算法交给客户类。如果要找出信誉度等级为A的客户,利用面向对象的查询方式很容易表示,如:
select User from User where User.getCreditDegree() = 'A'
但是,ORM(对象关系映射机制)无法将这条语句转换成标准SQL,唯一可行的办法,就是将数据库中的所有客户不带过滤条件的一一转换成User对象,然后调用该对象的getCreditDegree()方法进行检验。在系统数据量较大的情况下,这么做的性能是很慢的。
分析:
上述问题的原因是,系统必须把大量数据通过网络传到客户端,而无法在服务器端进行过滤,以减少网络上的数据传输。
解决:
如果抛开关系数据库,做一个嵌入式的Java存储系统,上述问题可以得到解决。