I am trying to write a query in SQL server to find out if there are any multiple rows for each customer by customerID. Please let me know.
Here is the table structure
Customer table
-----------------------------------------
orderID CustName CustomerID
---------------------------------------
100 test 123456
101 test 123456
Orders table
------------------------------------
pID OrderID
-----------------------------------
1 100
2 101
You can use a GROUP BY
query to achieve this:
select CustomerID, count(*) as NumDuplicates
from Customer
group by CustomerID
having count(*) > 1
To see how many of each customer you have:
SELECT COUNT(*), CustName, CustomerID
from Customer
Group by CustName, CustomerID
You can use a having
clause to limit to just duplicates:
SELECT COUNT(*), CustName, CustomerID
from Customer
Group by CustName, CustomerID
having count(*) > 1
UPDATE
To get those with successful orders:
select count(*), CustName, CustomerID
from(
SELECT CustName, CustomerID
from Customer, orders
where customer.orderID = orders.orderID
and orders.success = 1) subquery
group by subquery.CustName, subquery.CustomerID
having count(*) > 1;
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With