V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hananonamida
V2EX  ›  程序员

Django ORM 查询问题

  •  
  •   hananonamida · 2022-01-11 09:54:17 +08:00 · 1922 次点击
    这是一个创建于 1045 天前的主题,其中的信息可能已经有所发展或是发生改变。
    SELECT
    	* 
    FROM
    	"woocommerce_shoporder" 
    WHERE
    	shop_id = '5' 
    	AND transaction_id != '' 
    	AND ( order_type IS NULL OR order_type != 'presto_mart_child_order' ) 
    	AND NOT fulfillment_status = 'fulfilled' 
    	AND EXISTS ( SELECT * FROM "woocommerce_shoporderitem" WHERE woocommerce_shoporderitem.order_id = woocommerce_shoporder.ID AND woocommerce_shoporderitem.sku_id IS NOT NULL AND woocommerce_shoporderitem.is_retail != TRUE ) 
    	AND NOT (
    		(
    		SELECT COUNT
    			( item.* ) 
    		FROM
    			woocommerce_shoporderitem item
    			LEFT JOIN woocommerce_externalorder ON item.ID = woocommerce_externalorder.shop_order_item_id 
    		WHERE
    			item.sku_id IS NOT NULL 
    			AND item.is_retail != TRUE 
    			AND item.order_id = woocommerce_shoporder.ID 
    			AND woocommerce_externalorder.status IN ( 3, 4 ) 
    		) = ( SELECT COUNT ( item2.* ) FROM woocommerce_shoporderitem item2 WHERE item2.order_id = woocommerce_shoporder.ID AND item2.sku_id IS NOT NULL ) 
    	)
    

    求助,如何把以上 SQL 语句翻译为 Django ORM 形式的查询

    8 条回复    2022-01-12 13:21:28 +08:00
    Morriaty
        1
    Morriaty  
       2022-01-11 10:05:46 +08:00
    我 hive 都用不到你这么复杂的 sql ,你应该做的是优化表结构
    ddmasato
        2
    ddmasato  
       2022-01-11 10:12:10 +08:00
    不是可以使用 raw 吗
    hananonamida
        3
    hananonamida  
    OP
       2022-01-11 10:30:46 +08:00
    @ddmasato 因为还有别的条件,不太想用插入的形式
    weizhen199
        4
    weizhen199  
       2022-01-11 10:56:23 +08:00
    师傅别念了,不行写点中间表吧
    vanwtf
        5
    vanwtf  
       2022-01-11 12:04:48 +08:00
    试着写了下,不知道能不能给你提供思路


    ws_list = WoocommerceShoporderModel.objects.filter(
    shop_id = '5',
    transaction_id != '',
    (Q(order_type is None) | Q(transaction_id != '')),
    fulfillment_status != 'fulfilled'
    )

    new_ws = WoocommerceShoporderModel.objects.none()

    for ws in ws_list:
    wi = woocommerce_shoporderitem.objects.filter(
    order_id=ws.id,sku_id !=None,is_retail != True)
    item2_count = Item2Model.objects.filter(order_id=ws.id,sku_id!=None).count()
    item1_count = ItmeModel.objects.filter(
    sku_id != None,
    is_retail != True,
    order_id=ws.id,
    status__in=[3,4]).count()

    if wi and (item1_count != item2_count):
    # 这个写法不一定对,太久没用忘了怎么写了
    new_ws |= [ws]
    dayeye2006199
        6
    dayeye2006199  
       2022-01-11 14:54:11 +08:00
    直接.raw 把,别勉强
    wuwukai007
        7
    wuwukai007  
       2022-01-11 15:33:05 +08:00
    .raw 不太行 ,用 RawSQL 不是 raw ,是 RawSQL
    allisone
        8
    allisone  
       2022-01-12 13:21:28 +08:00
    与其贴 sql 不如说下业务逻辑设计到哪些模型,可能还能给你写思路。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1053 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 19:29 · PVG 03:29 · LAX 11:29 · JFK 14:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.