对象关系映射机制的不足

问题:

在某信誉度评估系统中,客户的信誉度是由与客户相关的信息根据一定算法综合评定产生的。假如根据用户贷款以及还款情况评定,按照面向对象方法,将有客户类、贷款类、还款类。客户类要使用链表等表示客户与贷款,还款之间的一对多关系,评定算法交给客户类。如果要找出信誉度等级为A的客户,利用面向对象的查询方式很容易表示,如:

select User from User where User.getCreditDegree() = 'A'

但是,ORM(对象关系映射机制)无法将这条语句转换成标准SQL,唯一可行的办法,就是将数据库中的所有客户不带过滤条件的一一转换成User对象,然后调用该对象的getCreditDegree()方法进行检验。在系统数据量较大的情况下,这么做的性能是很慢的。

分析:

上述问题的原因是,系统必须把大量数据通过网络传到客户端,而无法在服务器端进行过滤,以减少网络上的数据传输。

解决:

如果抛开关系数据库,做一个嵌入式的Java存储系统,上述问题可以得到解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值