Untitled

 avatar
user_4749604
plain_text
8 months ago
5.8 kB
3
Indexable
Never
-- 17. แสดงข้อมูลว่า ลูกค้าแต่ละคนซื้อ product ใดบ้าง และมียอดสั้งซื้อของแต่ละ product เท่าใด
SELECT
    c.name AS customer_name,
    p.name AS product_name,
    oi.amount * oi.price AS total_order_amount
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
JOIN
    order_items oi ON o.id = oi.order_id
JOIN
    products p ON oi.product_id = p.id;


-- 18. แสดงชื่อลูกค้าที่มียอดสั่งไฮยีน่ามากสุด 5 อันดับแรก
SELECT
    c.name AS customer_name,
    SUM(oi.amount * oi.price) AS total_order_amount
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
JOIN
    order_items oi ON o.id = oi.order_id
WHERE
    oi.product_id = 10 -- ID ของสินค้าไฮยีน่า
GROUP BY
    c.name
ORDER BY
    total_order_amount DESC
LIMIT 5;


-- 19. จงหาชื่อ customer ที่มียอดสั่งซื้อมากกว่า 10000
SELECT
    c.name AS customer_name,
    SUM(oi.amount * oi.price) AS total_order_amount
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
JOIN
    order_items oi ON o.id = oi.order_id
GROUP BY
    c.name
HAVING
    total_order_amount > 10000;


-- 20. แสดงชื่อเซลล์และยอดขาย เฉพาะคนที่ยอดขายมากกว่าค่าเฉลี่ย (ยอดรวม / จำนวนขาย)
SELECT
    e.name AS employee_name,
    SUM(oi.amount * oi.price) AS total_sales
FROM
    employees e
LEFT JOIN
    orders o ON e.id = o.employee_id
LEFT JOIN
    order_items oi ON o.id = oi.order_id
WHERE
    o.date IS NOT NULL
GROUP BY
    e.name
HAVING
    total_sales > (SELECT AVG(total_sales) FROM (SELECT SUM(oi.amount * oi.price) AS total_sales FROM order_items oi GROUP BY oi.order_id) AS avg_sales);


-- 21. แสดงชื่อ employee ที่ไม่มียอดขาย และแสดงลูกค้าที่ไม่มียอดซื้อ (2 results)
SELECT
    e.name AS employee_name
FROM
    employees e
LEFT JOIN
    orders o ON e.id = o.employee_id
WHERE
    o.date IS NULL;

SELECT
    c.name AS customer_name
FROM
    customers c
LEFT JOIN
    orders o ON c.id = o.customer_id
WHERE
    o.date IS NULL;


-- 22. จงหาชื่อลูกค้าและยอดซื้อโดยที่ยอดซื้อมีค่าสูงที่สุดในกลุ่มลูกค้าที่มียอดซื้อต่ำกว่าค่าเฉลี่ย
WITH CustomerTotalOrder AS (
    SELECT
        c.name AS customer_name,
        SUM(oi.amount * oi.price) AS total_order_amount
    FROM
        customers c
    JOIN
        orders o ON c.id = o.customer_id
    JOIN
        order_items oi ON o.id = oi.order_id
    GROUP BY
        c.name
)
SELECT
    customer_name,
    total_order_amount
FROM
    CustomerTotalOrder
WHERE
    total_order_amount = (SELECT MAX(total_order_amount) FROM CustomerTotalOrder WHERE total_order_amount < (SELECT AVG(total_order_amount) FROM CustomerTotalOrder));


-- 23. จงหาชื่อลูกค้าที่มีออเดอร์จากการซื้อแบบไม่ผ่านเซลล์มากสุด
SELECT
    c.name AS customer_name,
    COUNT(o.employee_id) AS total_orders
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
WHERE
    o.employee_id IS NULL
GROUP BY
    c.name
ORDER BY
    total_orders DESC
LIMIT 1;

-- 24. จงหาชื่อลูกค้าที่ไม่เคยซื้อสินค้าจากผู้ผลิตไท เอฟเวอเรสต์
SELECT DISTINCT
    c.name AS customer_name
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
JOIN
    order_items oi ON o.id = oi.order_id
JOIN
    products p ON oi.product_id = p.id
JOIN
    suppliers s ON p.supplier_id = s.id
WHERE
    s.name <> 'ไท เอฟเวอเรสต์';


-- 25. จงหาชื่อลูกค้าที่เคยซื้อน้ำดื่มคชสารและน้ำดื่มแมมมอธ
SELECT
    c.name AS customer_name
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
JOIN
    order_items oi ON o.id = oi.order_id
JOIN
    products p ON oi.product_id = p.id
WHERE
    p.name IN ('น้ำดื่มตรา คชสาร', 'น้ำดื่มตรา แมมมอธ');


-- 26. จงหาชื่อลูกค้าที่เคยซื้อไท อาเซียน แอตแลนติกแต่ไม่เคยซื้อไท เอฟเวอเรสต์
SELECT
    c.name AS customer_name
FROM
    customers c
JOIN
    orders o ON c.id = o.customer_id
JOIN
    order_items oi ON o.id = oi.order_id
JOIN
    products p ON oi.product_id = p.id
JOIN
    suppliers s ON p.supplier_id = s.id
WHERE
    s.name = 'ไท อาเซียน แอตแลนติก' AND c.name NOT IN (
        SELECT DISTINCT
            c2.name
        FROM
            customers c2
        JOIN
            orders o2 ON c2.id = o2.customer_id
        JOIN
            order_items oi2 ON o2.id = oi2.order_id
        JOIN
            products p2 ON oi2.product_id = p2.id
        JOIN
            suppliers s2 ON p2.supplier_id = s2.id
        WHERE
            s2.name = 'ไท เอฟเวอเรสต์'
    );

Leave a Comment