每个俱乐部会员的WooCommerce购买摘要({SQL})

时间:2018-11-05 14:16:54

标签: mysql sql wordpress woocommerce

我正在为我们的俱乐部创建两个“用户管理”页面,以便他们可以看到其每个会员在WooCommerce中购买的商品。我已经完成了大部分的mySQL查询,只需要完成一些小问题(有点麻烦)。

SELECT
    wp_users.ID,
    wp_users.display_name AS 'Name',
    wp_ihc_user_levels.level_id AS 'Roles',

    -- Check if User if full member or club visitor
    (CASE wp_usermeta.meta_key = 'club_member'
        WHEN wp_usermeta.meta_value LIKE 'Visitor' THEN 'Sponsored Visitor'
        WHEN wp_usermeta.meta_value LIKE 'Member' THEN 'Financial Member'
    END) AS 'Membership',

    -- Check if Member has purchased any items, by "category"
    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wp_terms
            WHERE wp_users.ID AND name = 'Camping') AS 'Camping',
    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wp_terms
            WHERE wp_users.ID AND name = 'Merchandise') AS 'Merchandise',
    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wp_terms
            WHERE wp_users.ID AND name = 'Catering') AS 'Catering',
    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wp_terms
            WHERE wp_users.ID AND name = 'Tickets') AS 'Tickets',

    -- Check if Member has booked any trips
    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wp_em_bookings WHERE person_id = wp_users.ID) AS 'Trips'
FROM
    wp_users
    JOIN wp_usermeta ON wp_users.ID = wp_usermeta.user_id
    JOIN wp_ihc_user_levels ON wp_users.ID = wp_ihc_user_levels.user_id
WHERE
    wp_usermeta.meta_value = (SELECT MAX(CASE WHEN meta_key = 'affiliated_club' THEN meta_value END) FROM wp_usermeta WHERE user_id = '17')

因此,SQL查询将以调用该查询的user_id身份运行,然后它将在“ affiliate_club”中找到所有其他俱乐部成员,并从顶部运行SELECT查询。

问题是:

  1. 用户可以在“ wp_ihc_user_levels.level_id”中担任多个角色,但是查询返回的是“ 4”和“ 5”的两行,而不是CONCAT,即同一行中的“ 4,5”。
  2. 案例wp_usermeta.meta_key ='club_member'正在为所有具有某些完整成员的条目返回“访问者”
  3. 我不确定需要查询哪些WooCommerce表,以将Category链接到每个wp_users.ID购买的商品。

第二个查询,我需要使用从查询一返回的“ wp_users.ID”,以按类别对每个WooCommerce购买进行更详细的扩展。

如果我进一步了解WooCommerce查询,我可能可以完成大部分第二个查询。

谢谢。

更新1:

好的,所以我能够整理出Point 1:

已更改:

wp_ihc_user_levels.level_id AS 'Roles',

收件人:

(SELECT GROUP_CONCAT(level_id SEPARATOR ',')
    FROM wp_ihc_user_levels
    WHERE user_id = wp_users.ID) AS 'Roles',

现在,“角色”显示的值为“ 2、3、5”等。而不是单个值

更新2:

好的,所以我现在整理了第二点:

已更改:

(CASE wp_usermeta.meta_key = 'club_member'
    WHEN wp_usermeta.meta_value LIKE 'Visitor' THEN 'Sponsored Visitor'
    WHEN wp_usermeta.meta_value LIKE 'Member' THEN 'Financial Member'
END) AS 'Membership',

收件人:

(SELECT wp_usermeta.meta_value
    FROM wp_usermeta
    WHERE wp_usermeta.meta_key = 'club_member' AND wp_usermeta.user_id = wp_users.ID) AS 'Membership',

更新3:SQL查询已完成

好吧,所以这要么是一个非常复杂的SQL查询,要么我把它的结构都弄错了,但下面是我的有效解决方案。

注意::%CURRENT_USER_ID%占位符用于调用当前用户ID(与其他成员位于同一俱乐部中)。

SELECT DISTINCT
    wpdc_users.ID,
    wpdc_users.display_name AS 'Name',

    (SELECT wpdc_usermeta.meta_value
        FROM wpdc_usermeta
        WHERE wpdc_usermeta.meta_key = 'club_member' AND wpdc_usermeta.user_id = wpdc_users.ID) AS 'Membership',

    (SELECT GROUP_CONCAT(level_id SEPARATOR ',')
        FROM wpdc_ihc_user_levels
        WHERE user_id = wpdc_users.ID) AS 'Roles',

    (SELECT
        IF(SUM(wpdc_terms.name = 'Camping')     >0, 'Yes', 'No')

    FROM
        wpdc_postmeta
        JOIN wpdc_woocommerce_order_items ON wpdc_woocommerce_order_items.order_id = wpdc_postmeta.post_id
        JOIN wpdc_woocommerce_order_itemmeta ON wpdc_woocommerce_order_items.order_item_id = wpdc_woocommerce_order_itemmeta.order_item_id
        JOIN wpdc_term_relationships ON wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        JOIN wpdc_terms ON wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id

    WHERE
        wpdc_postmeta.meta_key = '_customer_user'
        AND wpdc_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        AND wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id
        AND wpdc_terms.term_id > 23
        AND wpdc_postmeta.meta_value =  wpdc_users.ID) AS 'Camping',

    (SELECT
        IF(SUM(wpdc_terms.name = 'Catering')    >0, 'Yes', 'No')

    FROM
        wpdc_postmeta
        JOIN wpdc_woocommerce_order_items ON wpdc_woocommerce_order_items.order_id = wpdc_postmeta.post_id
        JOIN wpdc_woocommerce_order_itemmeta ON wpdc_woocommerce_order_items.order_item_id = wpdc_woocommerce_order_itemmeta.order_item_id
        JOIN wpdc_term_relationships ON wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        JOIN wpdc_terms ON wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id

    WHERE
        wpdc_postmeta.meta_key = '_customer_user'
        AND wpdc_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        AND wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id
        AND wpdc_terms.term_id > 23
        AND wpdc_postmeta.meta_value =  wpdc_users.ID) AS 'Catering',

    (SELECT
        IF(SUM(wpdc_terms.name = 'Merchandise') >0, 'Yes', 'No')

    FROM
        wpdc_postmeta
        JOIN wpdc_woocommerce_order_items ON wpdc_woocommerce_order_items.order_id = wpdc_postmeta.post_id
        JOIN wpdc_woocommerce_order_itemmeta ON wpdc_woocommerce_order_items.order_item_id = wpdc_woocommerce_order_itemmeta.order_item_id
        JOIN wpdc_term_relationships ON wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        JOIN wpdc_terms ON wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id

    WHERE
        wpdc_postmeta.meta_key = '_customer_user'
        AND wpdc_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        AND wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id
        AND wpdc_terms.term_id > 23
        AND wpdc_postmeta.meta_value =  wpdc_users.ID) AS 'Merchandise',

    (SELECT
        IF(SUM(wpdc_terms.name = 'Tickets')     >0, 'Yes', 'No')

    FROM
        wpdc_postmeta
        JOIN wpdc_woocommerce_order_items ON wpdc_woocommerce_order_items.order_id = wpdc_postmeta.post_id
        JOIN wpdc_woocommerce_order_itemmeta ON wpdc_woocommerce_order_items.order_item_id = wpdc_woocommerce_order_itemmeta.order_item_id
        JOIN wpdc_term_relationships ON wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        JOIN wpdc_terms ON wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id

    WHERE
        wpdc_postmeta.meta_key = '_customer_user'
        AND wpdc_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wpdc_term_relationships.object_id = wpdc_woocommerce_order_itemmeta.meta_value
        AND wpdc_terms.term_id = wpdc_term_relationships.term_taxonomy_id
        AND wpdc_terms.term_id > 23
        AND wpdc_postmeta.meta_value =  wpdc_users.ID) AS 'Tickets',

    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wpdc_em_bookings WHERE person_id = wpdc_users.ID) AS 'Trips / Events'
FROM
    wpdc_users
    JOIN wpdc_usermeta ON wpdc_usermeta.user_id = wpdc_users.ID
    JOIN wpdc_ihc_user_levels ON wpdc_users.ID = wpdc_ihc_user_levels.user_id

WHERE
    wpdc_usermeta.meta_value = (SELECT MAX(CASE WHEN meta_key = 'affiliated_club' THEN meta_value END) FROM wpdc_usermeta WHERE user_id = %CURRENT_USER_ID%)

我要将此问题标记为已解决,但是如果有人能够建议是否可以将其压缩/最小化以更有效地运行以检查每个类别购买,则将不胜感激。

谢谢。

1 个答案:

答案 0 :(得分:0)

更新3:SQL查询已完成

好吧,所以这要么是一个非常复杂的SQL查询,要么我把它的结构都弄错了,但下面是我的有效解决方案。

注意::%CURRENT_USER_ID%占位符用于调用当前用户ID(与其他成员位于同一俱乐部中)。

SELECT DISTINCT
    wp_users.ID,
    wp_users.display_name AS 'Name',

    (SELECT wp_usermeta.meta_value
        FROM wp_usermeta
        WHERE wp_usermeta.meta_key = 'club_member' AND wp_usermeta.user_id = wp_users.ID) AS 'Membership',

    (SELECT GROUP_CONCAT(level_id SEPARATOR ',')
        FROM wp_ihc_user_levels
        WHERE user_id = wp_users.ID) AS 'Roles',

    (SELECT
        IF(SUM(wp_terms.name = 'Camping')     >0, 'Yes', 'No')

    FROM
        wp_postmeta
        JOIN wp_woocommerce_order_items ON wp_woocommerce_order_items.order_id = wp_postmeta.post_id
        JOIN wp_woocommerce_order_itemmeta ON wp_woocommerce_order_items.order_item_id = wp_woocommerce_order_itemmeta.order_item_id
        JOIN wp_term_relationships ON wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        JOIN wp_terms ON wp_terms.term_id = wp_term_relationships.term_taxonomy_id

    WHERE
        wp_postmeta.meta_key = '_customer_user'
        AND wp_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        AND wp_terms.term_id = wp_term_relationships.term_taxonomy_id
        AND wp_terms.term_id > 23
        AND wp_postmeta.meta_value =  wp_users.ID) AS 'Camping',

    (SELECT
        IF(SUM(wp_terms.name = 'Catering')    >0, 'Yes', 'No')

    FROM
        wp_postmeta
        JOIN wp_woocommerce_order_items ON wp_woocommerce_order_items.order_id = wp_postmeta.post_id
        JOIN wp_woocommerce_order_itemmeta ON wp_woocommerce_order_items.order_item_id = wp_woocommerce_order_itemmeta.order_item_id
        JOIN wp_term_relationships ON wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        JOIN wp_terms ON wp_terms.term_id = wp_term_relationships.term_taxonomy_id

    WHERE
        wp_postmeta.meta_key = '_customer_user'
        AND wp_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        AND wp_terms.term_id = wp_term_relationships.term_taxonomy_id
        AND wp_terms.term_id > 23
        AND wp_postmeta.meta_value =  wp_users.ID) AS 'Catering',

    (SELECT
        IF(SUM(wp_terms.name = 'Merchandise') >0, 'Yes', 'No')

    FROM
        wp_postmeta
        JOIN wp_woocommerce_order_items ON wp_woocommerce_order_items.order_id = wp_postmeta.post_id
        JOIN wp_woocommerce_order_itemmeta ON wp_woocommerce_order_items.order_item_id = wp_woocommerce_order_itemmeta.order_item_id
        JOIN wp_term_relationships ON wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        JOIN wp_terms ON wp_terms.term_id = wp_term_relationships.term_taxonomy_id

    WHERE
        wp_postmeta.meta_key = '_customer_user'
        AND wp_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        AND wp_terms.term_id = wp_term_relationships.term_taxonomy_id
        AND wp_terms.term_id > 23
        AND wp_postmeta.meta_value =  wp_users.ID) AS 'Merchandise',

    (SELECT
        IF(SUM(wp_terms.name = 'Tickets')     >0, 'Yes', 'No')

    FROM
        wp_postmeta
        JOIN wp_woocommerce_order_items ON wp_woocommerce_order_items.order_id = wp_postmeta.post_id
        JOIN wp_woocommerce_order_itemmeta ON wp_woocommerce_order_items.order_item_id = wp_woocommerce_order_itemmeta.order_item_id
        JOIN wp_term_relationships ON wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        JOIN wp_terms ON wp_terms.term_id = wp_term_relationships.term_taxonomy_id

    WHERE
        wp_postmeta.meta_key = '_customer_user'
        AND wp_woocommerce_order_itemmeta.meta_key = '_product_id'
        AND wp_term_relationships.object_id = wp_woocommerce_order_itemmeta.meta_value
        AND wp_terms.term_id = wp_term_relationships.term_taxonomy_id
        AND wp_terms.term_id > 23
        AND wp_postmeta.meta_value =  wp_users.ID) AS 'Tickets',

    (SELECT IF(COUNT(*) > 0, 'Yes', 'No') FROM wp_em_bookings WHERE person_id = wp_users.ID) AS 'Trips / Events'
FROM
    wp_users
    JOIN wp_usermeta ON wp_usermeta.user_id = wp_users.ID
    JOIN wp_ihc_user_levels ON wp_users.ID = wp_ihc_user_levels.user_id

WHERE
    wp_usermeta.meta_value = (SELECT MAX(CASE WHEN meta_key = 'affiliated_club' THEN meta_value END) FROM wp_usermeta WHERE user_id = %CURRENT_USER_ID%)

我要将此问题标记为已解决,但是如果有人能够建议是否可以将其压缩/最小化以更有效地运行以检查每个类别购买,则将不胜感激。

谢谢。