winbug2008 2012-05-03 05:57
浏览 337
已采纳

sql 中两个条件 问题

我现在有一个表查询, 要用两个字段来都符合条件 来查询结果
SELECT *
FROM orders
WHERE quantity =1 AND customer = 'Tizag'

现在遇到的问题是
现在我们有一组的的数据 要查询 最简单的做法是Java里写一个循环是
for(int i=0;i<listA.size();i++){
SELECT *
FROM orders
WHERE (quantity =listA.get(0) AND customer = listB.get(0))
}

然后一条一条连接数据库查, 这样速度非常慢
或者写成一条语句
SELECT *
FROM orders
WHERE (quantity =listA.get(0) AND customer = listB.get(0))
OR (quantity =listA.get(1) AND customer = listA.get(1))
OR (quantity =listA.get(2) AND customer = listA.get(2))

这个LIST 可能有100K 条记录 这样就造成了SQL 非常的长。
而一条一条查要100K次

数据库是 oracle

大家有什么其他好的建议没有。谢谢。

  • 写回答

8条回答 默认 最新

  • iteye_16709 2012-05-03 10:25
    关注

    1.语法错误;
    [code="SQL"]select * from orders connect by prior quantity = ? and prior customer =?start with quantity =1 AND customer = 'Tizag' [/code]
    改为:
    [code="SQL"]select * from orders start with quantity =1 AND customer = 'Tizag' connect by prior quantity = ? and prior customer =?[/code]

    2.start with ...connect by prior...是层次查询语法。
    语法形式:
    [code="Sql"]select level column_name ,expression,... from
    table_name
    [where where_condition]
    start with start_condition
    connect by prior prior_condition[/code]

    3.该问题并不是层次查询问题。

    4.该问题由于你的list中有100k的记录也就是10万条记录。建议
    使用临时表分批查询。将查询结果放在临时表中。
    需要注意一下几点:
    1.采用PrepareStatement,减少硬解析;
    2.减少连接次数,不要在循环中频繁查询;
    3.为了提高查询效率,创建一个索引,在查询条件中最好
    附带上该索引;
    4.可以考虑使用缓存技术,mencache等等。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(7条)

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?