简单查询数据库,减轻多字段表及数据库压力

最近在查询标签收费记录时,要在列表中显示车牌号信息,而车牌号信息在标签信息记录表中,于是需要查询标签信息记录,最原始的做法:
获取分页的一页记录数据,循环遍历得出标签收费记录对象,然后通过标签收费记录中的标签ID来查询标签信息对象,保存在List对象中:

List vehicleList =new ArrayList();
if(rs.list!=null && rs.list.size()>0){
for(int i=0;i<rs.list.size();i++)
{
UrpcsConsumptionRecord recod =(UrpcsConsumptionRecord)rs.list.get(i);
if(recod!=null)
{
[color=red]UrpcsVehicle vehicle =vehicleDs.search(recod.getVehicleId());[/color] vehicleList.add(vehicle);
}
}
}

对于上述操作,我特别提出vehicleDs.search(ID)方法,对于拥有众多字段的标签信息来说,查询整条记录,务必会影响查询效率和对数据库产生压力,看看search的实现方法:
public UrpcsVehicle search(String vehicleId) {
return load(UrpcsVehicle.class, vehicleId);
}
对于此操作,造成后台不断打印出很多关于search记录(一页显示20条记录,1秒钟打印出20条search查询结果),如果频繁查询收费信息,会对数据库造成很大压力,直至拖垮数据库!
对此,我想到只需要获取收费信息中一个标签数组,这样不用循环查询标签信息,是否能提高效率,提高性能啦!做法如下:
List vehicleList =new ArrayList();
if(rs.list!=null && rs.list.size()>0){
Object[] objs =new Object[rs.list.size()];
for(int i=0;i<rs.list.size();i++)
{
UrpcsConsumptionRecord recod =(UrpcsConsumptionRecord)rs.list.get(i);
if(recod!=null)
{
objs[i] =recod.getVehicleNumber();
}
}
[color=red]vehicleList=vehicleDs.queryVehicleById(objs);[/color] }

很明显,这样查询不必频繁查询标签信息记录,效率也会相应提高,后台输出也会相应减少!
来看看vehicleDs.queryVehicleById(objs[])来如何操作的:
public List queryVehicleById(Object[] vehicleNumber){
DetachedCriteria criteria =DetachedCriteria.forClass(UrpcsVehicle.class);
[color=red]criteria.add(Expression.in("vehicleNumber",vehicleNumber));[/color] return getHibernateTemplate().findByCriteria(criteria);
}
虽然此方法使用了in查询,在一定程度上影响了数据库效率,但相对上面的查询,还是相对效率高些(个人看法)

下面来看看一般如何获取object[]数组的:
public Object[] getPopedomRole(final int RoleID){
return (Object[]) getHibernateTemplate().execute(
new HibernateCallback() {
public Object doInHibernate(Session session) throws HibernateException, SQLException {
String sql = "select popedomId from UrpcsPopedomRole a where a.roleId="+RoleID+"";
Query query = session.createQuery(sql);
List list = query.list(); return list.toArray();
}
});
}
一般如此得到一个表中的一个字段的记录,但上面的内容无需采用此方法,直接循环把内容存入到数组中即可!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值