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

The calling thread must be STA, because many UI components require this.

Using Thread: // Create a thread Thread newWindowThread = new Thread(new ThreadStart(() => { // You can use your code // Create and show the Window FaxImageLoad obj = new FaxImageLoad(destination); obj.Show(); // Start the Dispatcher Processing System.Windows.Threading.Dispatcher.Run(); })); // Set the apartment state newWindowThread.SetApartmentState(ApartmentState.STA); // Make the thread a background thread newWindowThread.IsBackground = true; // Start the thread newWindowThread.Start(); Using Task and Thread: // Creating Task Pool, Each task will work asyn and as an indivisual thread component Task[] tasks = new Task[3]; // Control drug data disc UI load optimize tasks[0] = Task.Run(() => { //This will handle the ui thread :The calling thread must be STA, because many U...

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=...

An error occurred while updating the entries. See the inner exception for details.

If you are using EF then you may get the error. This error is not specify where the error exactly occur in your table. To specify the error use this code & use debugger to see the exact error message. try { //Your code db = new FEDALIC_AGRI_DBEntities (); model.FarmerVillage = new Guid(village); model.FarmerThana = new Guid(thana); model.FarmerDistrict = new Guid(district); var _SET_FARMER_INFO = EMFermar.SetToModelObject(model); db.SET_FARMER_INFO.Add(_SET_FARMER_INFO); db.SaveChanges(); } catch (DbUpdateException e) { var innerEx = e.InnerException; while (innerEx.InnerException != null) innerEx = innerEx.InnerException; throw new Exception(innerEx.Message); } catch (DbEntityValidationException e...