Skip to main content

Get the difference between two dates in years,months and days as a string from a SQL Server

Just use the function pass 2 date parameter & get your expected Year/Month/Day
SELECT  [dbo].[fnGetDateDiffAsYMD] ('01/01/2012','02/02/2014')as Duration  





 set ANSI_NULLS ON  
 set QUOTED_IDENTIFIER ON  
 go  
 --SELECT [dbo].[fnGetDateDiffAsYMD] ('01/01/2012','02/02/2013')   
 ALTER FUNCTION [dbo].[fnGetDateDiffAsYMD] (@FromDate AS DateTime,@ToDate AS DATETIME)  
 RETURNS VARCHAR(30)  
 AS  
 BEGIN  
      DECLARE @date datetime,  
                @tmpdate datetime,  
                @years int,  
                @months int,  
                @days int,  
                @exp varchar(30),  
                @mm int,  
                @experiance datetime  
 if (datediff(dd,@FromDate ,@ToDate)< 0) or (@FromDate='') or (@ToDate is null)  
    select @exp ='Invalid joining date'  
 else  
 begin  
    select @experiance=Dateadd(yy,Datediff(yy,@FromDate,@ToDate),@fromDate)  
    select @years=Datediff(yy,@FromDate,@ToDate) - (CASE  
 WHEN @experiance > @ToDate THEN 1  
 ELSE 0  
 END)  
      select @months=Month(@ToDate - @experiance) -1  
      select @days = Day(@ToDate - @experiance) - 1  
 if @years<=0 and @months<=0 and @days<=0  
      set @exp = '0';  
 else if @years<=0  
 begin  
      if @months>0  
 begin  
      if @days>0  
 begin  
      if @months>1  
 begin  
      if @days>1  
      set @exp= CAST(@months as varchar) + ' months' +' and ' + CAST(@days as varchar) + ' Days'  
 else if @days=1  
      set @exp= CAST(@months as varchar) + ' months' +' and ' + CAST(@days as varchar) + ' Day'  
 end  
      else if @months=1  
 begin  
 if @days>1  
      set @exp= CAST(@months as varchar) + ' month' +' and ' + CAST(@days as varchar) + ' Days'  
 else if @days=1  
      set @exp= CAST(@months as varchar) + ' month' +' and ' + CAST(@days as varchar) + ' Day'  
 end  
 end  
 else if @days<=0  
 begin  
 if @months>1  
      set @exp= CAST(@months as varchar) + ' months'  
 else if @months=1  
      set @exp= CAST(@months as varchar) + ' month'  
 end  
 end  
 else if @months<=0  
 if @days>1  
      set @exp = CAST(@days as varchar) + ' Days'  
 else if @days=1  
      set @exp = CAST(@days as varchar) + ' Day'  
 end  
 else if @years>0 and @months>0 and @days>0  
 begin  
  if @years>1  
 begin  
 if @months>1  
 begin  
 if @days>1  
  set @exp= CAST(@years as varchar) +' Years' + ', '+ CAST(@months as varchar) + ' months' +' and ' + CAST(@days as varchar) + ' Days'  
 else if @days=1  
      set @exp= CAST(@years as varchar) +' Years' + ', '+ CAST(@months as varchar) + ' months' +' and ' + CAST(@days as varchar) + ' Day'  
 end  
 else if @months=1  
 begin  
 if @days>1  
 set @exp= CAST(@years as varchar) +' Years' + ', '+ CAST(@months as varchar) + ' month' +' and ' + CAST(@days as varchar) + ' Days'  
 else if @days=1  
 set @exp= CAST(@years as varchar) +' Years' + ', '+ CAST(@months as varchar) + ' month' +' and ' + CAST(@days as varchar) + ' Day'  
 end  
 end  
 else if @years=1  
 begin  
 if @months>1  
 begin  
 if @days>1  
 set @exp= CAST(@years as varchar) +' Year' + ', '+ CAST(@months as varchar) + ' months ' +'and ' + CAST(@days as varchar) + ' Days'  
 else if @days=1  
 set @exp= CAST(@years as varchar) +' Year' + ', '+ CAST(@months as varchar) + ' months ' +'and ' + CAST(@days as varchar) + ' Day'  
 end  
 else if @months=1  
 begin  
 if @days>1  
 set @exp= CAST(@years as varchar) +' Year' + ', '+ CAST(@months as varchar) + ' month ' +'and ' + CAST(@days as varchar) + ' Days'  
 else if @days=1  
 set @exp= CAST(@years as varchar) +' Year' + ', '+ CAST(@months as varchar) + ' month ' +'and ' + CAST(@days as varchar) + ' Day'  
 end  
 end  
 end  
 else if @years>0 and @days>0 and @months<=0  
 begin  
 if(@years>1)  
 begin  
 if(@days>1)  
 set @exp = CAST(@years as varchar) +' Years' +' and ' + CAST(@days as varchar) + ' Days'  
 else if(@days=1)  
 set @exp = CAST(@years as varchar) +' Years' +' and ' + CAST(@days as varchar) + ' Day'  
 end  
 else if(@years=1)  
 begin  
 if(@days>1)  
 set @exp = CAST(@years as varchar) +' Year' +' and ' + CAST(@days as varchar) + ' Days'  
 else if(@days=1)  
 set @exp = CAST(@years as varchar) +' Year' +' and ' + CAST(@days as varchar) + ' Day'  
 end  
 end  
 else if @years>0 and @days<=0 and @months<=0  
 begin  
 if @years>1  
 set @exp = CAST(@years as varchar) +' Years'  
 else if @years=1  
 set @exp = CAST(@years as varchar) +' Year'  
 end  
 else if @years>0 and @days<=0 and @months>0  
 begin  
 if @years>1  
 begin  
 if @months>1  
 set @exp = CAST(@years as varchar) +' Years' +' and ' + cast(@months as varchar) + ' months'  
 else if @months=1  
 set @exp = CAST(@years as varchar) +' Years' +' and ' + cast(@months as varchar) + ' month'  
 end  
 else if @years=1  
 begin  
 if @months>1  
 set @exp = CAST(@years as varchar) +' Year' +' and ' + cast(@months as varchar) + ' months'  
 else if @months=1  
 set @exp = CAST(@years as varchar) +' Year' +' and ' + cast(@months as varchar) + ' month'  
 end  
 end  
 end  
 return @exp  
 END  

you can also use

 SELECT DATEDIFF(DAY, GETDATE(), GETDATE() + 1) AS DayDiff  
 SELECT DATEDIFF(MINUTE, GETDATE(), GETDATE() + 1) AS MinuteDiff  
 SELECT DATEDIFF(SECOND, GETDATE(), GETDATE() + 1) AS SecondDiff  
 SELECT DATEDIFF(WEEK, GETDATE(), GETDATE() + 1) AS WeekDiff  
 SELECT DATEDIFF(HOUR, GETDATE(), GETDATE() + 1) AS HourDiff  

Comments

Popular posts from this blog

WPF datagrid cell textbox change event

Entity/Class: public class FeesDetails : INotifyPropertyChanged { public int Id { get; set; } public string FeesName { get; set;} public string FeesDetailsName { get; set; } public int? PaidAmount { get; set; } public event PropertyChangedEventHandler PropertyChanged; private void NotifyPropertyChanged(System.String info) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } } public int feesAmount { get; set; } public int FeesAmount { get { return this.feesAmount; } set { if (value != this.feesAmount) { this.feesAmount = value; NotifyPropertyChanged("FeesAmount"); } } } } XAML: <DataGrid AutoGenerateColumns="False" Height="21...

mvc razor textboxfor change event change another textboxfor value

Based on value of Weight, Rate , CNF & AWB it will change the value of Freight , TTLCNF anfd TTLFright . Freight= Weight*Rate; TTLCNF  = Weight*CNF; TTLFright=  Freight+ TTLCNF  + AWB; @Html.TextBoxFor(model => model.Weight, new { onChange="return GetWight(this);"}) @Html.TextBoxFor(model => model.Rate, new { onChange="return GetWight(this);"})/Kg @Html.TextBoxFor(model => model.Freight, new {disabled = "disabled" , @readonly = "readonly" ,onChange="return GetTTLFright(this);"}) @Html.TextBoxFor(model => model.CNFPK, new { onChange="return GetCNFPK(this);"}) @Html.TextBoxFor(model => model.TTLCNF, new {disabled = "disabled" , @readonly = "readonly",onChange="return GetTTLFright(this);" }) @Html.TextBoxFor(model => model.AWB, new { onChange="return GetTTLFright(this);"}) and script <script> function GetW...

mvvm double click event in listview

If you want to get the double click event on a listview item you can try with this code; <ListView Grid.Row="0" Grid.RowSpan="3" Grid.Column="0" Width="250" Height="200" HorizontalAlignment="Stretch" VerticalAlignment="Top" AlternationCount="2" BorderBrush="#FFA8CC7B" ItemContainerStyle="{StaticResource alternatingStyle}" ItemsSource="{Binding FromPayerNameList}" SelectedItem="{Binding SelectedFromPayer, Mode=TwoWay}"> <ListView.ItemTemplate> <DataTemplate> <TextBlock Width="{Binding Path=ActualWidth, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ListView}}}" Text=...