How do get the last payment Date using SQL [closed] - sql

Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 2 years ago.
Improve this question
Currently I'm using below SQL code
Last_Value (dbo.TransactionTable.TransDate)
over (PARTITION BY dbo.TransactionTable.TransNumber
Order by dbo.TransactionTable.TransNumber
Rows between UNBOUNDED PRECEDING and UNBOUNDED FOLLOWING)
as LastPaymentReceived
When I run the above SQL script it gives me 06/11/2021.wherein the most recent successful repayment should be 06/08/2020.The code works fine when if customer not missed the payment, Things get complicated when Customer DD returned with transaction posted "Unpaid DD - Instr Cancelled"
However, last payment date for this is 06/11/2021) but this payment was returned unpaid with a transaction posted to the account on 06/11/2021 with transaction posted "Unpaid DD - Instr Cancelled". Please see the Transactiondetail
Someone can advise me?
Many Thanks
Dan

The code you've given is only a snippet of a single item from a SELECT clause. If you want to return multiple rows for different customers, or multiple fields, the answer below may be difficult to integrate into the rest of your code.
SELECT TOP 1
t2.TransDate
FROM
TransactionTable t2
WHERE
NOT EXISTS (SELECT 1 FROM TransactionTable t1
WHERE t1.TransDate = t2.TransDate
AND t1.Description = 'Unpaid DD - Instr Cancelled')
ORDER BY
t2.TransDate DESC
You will need to add customer filters in the WHERE clause for both the main query and the subquery.

Related

How could I add a column which contains dates in my SQL query to get the monthly data [closed]

Closed. This question needs debugging details. It is not currently accepting answers.
Edit the question to include desired behavior, a specific problem or error, and the shortest code necessary to reproduce the problem. This will help others answer the question.
Closed 4 months ago.
Improve this question
I have two tables with many columns. One contains 50k custIDs, date & Payments received for every id and the other table contains 5k custIDs. I need to find How much payment received per CustId on monthly basis for these 5k CustIDs ?
Assuming your dates are stored as date...
select i.custId, i.custName,
to_char(p.payment_date,'yyyy-mm') as payment_month,
sum(p.amount_paid) as total_amount_paid
from customers i
join payments p
on i.custId = p.custId
group by i.custId, i.custName, to_char(p.payment_date,'yyyy-mm')

study year of that student [closed]

Closed. This question needs debugging details. It is not currently accepting answers.
Edit the question to include desired behavior, a specific problem or error, and the shortest code necessary to reproduce the problem. This will help others answer the question.
Closed 2 years ago.
Improve this question
Question was:
average grade for the whole study year of that student.
Select FirstName,LastName,Year,AverageGrade,
Avg AverageGrade Order by YearAverageGrade
from Student
You don't have a PARTITION BY clause. Unless you tell SQL server what the window is, it will use the entire dataset (it can't read your mind, and guess what you're after). I also doubt you need the ORDER BY in the window (as that would default to ORDER BY [Year] ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW). I assume you therefore want this:
SELECT FirstName,
LastName,
[Year],
AverageGrade,
AVG(AverageGrade) OVER (PARTITION BY [Year]) AS YearAverageGrade
FROM dbo.Student;

SQL Sub-Query Multiple Columns [closed]

Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 2 years ago.
Improve this question
I have a dataset containing a list of recorded coronavirus cases in countries across the world through a time period of December 2019 to April 2020. I am trying to write an SQL query to give a a cumulative total for the top ten countries through this time period (i.e. the countries with the highest total at the end).
I have started this by writing a query to give a cumulative total for all countries, and then have tried to write a sub-query to limit this list to only include the data for the top ten countries.
SELECT
Virus.dateRep,
Country.countriesAndTerritories,
SUM(Virus.cases) OVER (PARTITION BY Country.geoId ORDER BY Dates.year, Dates.month, Dates.day ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) AS 'cume_cases',
SUM(Virus.deaths) OVER (PARTITION BY Country.geoId ORDER BY Dates.year, Dates.month, Dates.day ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) AS 'cume_deaths'
FROM
Virus
INNER JOIN
Dates ON (Virus.dateRep = Dates.dateRep)
INNER JOIN
Country ON (Virus.geoId = Country.geoId)
WHERE Virus.geoId IN (SELECT
Virus.geoId, sum(Virus.cases) as 'total'
FROM
Virus
GROUP BY
Virus.geoId
ORDER BY
total
DESC
LIMIT 10)
GROUP BY
Country.geoId,
Virus.dateRep
ORDER BY
Dates.year,
Dates.month,
Dates.day,
Country.countriesAndTerritories
ASC;
However, the sub-query only allows for one column to be queried, and so is not working. Any solutions?
You can do this with only one column:
WHERE Virus.geoId IN (SELECT v.geoId
FROM Virus v
GROUP BY v.geoId
ORDER BY sum(Virus.cases) DESC
LIMIT 10
)

How to use group and sum same data based on different criteria on same table [closed]

Closed. This question needs details or clarity. It is not currently accepting answers.
Want to improve this question? Add details and clarify the problem by editing this post.
Closed 4 years ago.
Improve this question
I am trying to sum data in a table.
Data in my table:
Month Osl Sale
10 8-02-01-01 38440.5
10 8-02-01-03 14961
10 8-03-02-01 10388.3
10 8-05-04-01 81666.6
10 8-05-04-05 29431.8
10 8-07-01-09 9821.4
10 8-09-01-01 7567.5
And my expected output is:
I think union all is the simplest method:
select month, osl, sale
from t
union all
select month, left(osl, 7), sum(sale)
from t
group by month, left(osl, 7);
Not all databases support left(). In those that don't, either substr() or substring() can extract the first seven characters.
Unsure of your RDMS, but I would suggest something along the lines of:
select * from table1
union all
select t.month, left(t.osl, len(t.osl)-3), sum(t.sale)
from table1 t
group by t.month, left(t.osl, len(t.osl)-3)
Change table1 to your table name as appropriate.

SQL query to find current month from date [closed]

Closed. This question needs debugging details. It is not currently accepting answers.
Edit the question to include desired behavior, a specific problem or error, and the shortest code necessary to reproduce the problem. This will help others answer the question.
Closed 5 years ago.
Improve this question
The question is to Produce a list of the latest movies by genres for the current month. How to find the current month from the Date???
You are looking for DATEPART()
Select
*
From YourTable
Where
datepart(month,ReleaseDate) = datepart(month,getdate())
and datepart(year,ReleaseDate) = datepart(year,getdate())
Order by Genre, ReleaseDate desc
You can try this:
SELECT SUBSTRING(TO_CHAR(now(),'YYYYMMDD'),5,2)
In which:
Format to date and you get only the month