Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Få fram datum

Postades av 2004-12-01 09:03:28 - Peter Grafström, i forum sql-server/msde, Tråden har 7 Kommentarer och lästs av 758 personer

Vore tacksam om någon snabbt (jag vet att det är enkelt, men jag kommer inte loss) kan hjälpa mig med att i T-SQL ta fram ett datum som är:
- sista dagen i månaden innan, två år tillbaka i tiden.
- Om dagens datum är 2004-12-14, vill jag få fram 2002-11-30
- Om dagens datum är 2005-01-28, vill jag få fram 2002-12-31

Tackar
Peter



Svara

Sv: Få fram datum

Postades av 2004-12-01 11:19:28 - Mikael Wedham

SELECT DATEADD( d, -1, ( CAST(YEAR(GETDATE())-2 AS VARCHAR(4)) + '-' + CAST(MONTH(GETDATE())AS VARCHAR(2)) + '-01' ) )

/micke


Svara

Sv: Få fram datum

Postades av 2004-12-01 11:30:20 - Marcus Olsson

Varsågod!

<code>
select dateadd(yy,-2,getdate())-datepart(d,dateadd(yy,-2,getdate()))
</code>

Eller om du vill ha den som en UDF:

<code>
create function dbo.GetLastDayPrevMonthTwoYearsago(@d datetime) returns datetime
as
begin
return dateadd(yy,-2,@d)-datepart(d,dateadd(yy,-2,@d))
end
</code>

<code>
select dbo.GetLastDayPrevMonthTwoYearsago(valfritt datum)
</code>

MVH
Marcus Olsson
MCT, MCDBA, MCSD, MCSE+I


Svara

Sv:Få fram datum

Postades av 2004-12-02 00:30:08 - Per Karlsson

Snyggt, Marcus!
Tillåter mig dock att förkorta lite:
<CODE>
select dateadd(yy,-2,getdate()) - day(getdate())
</CODE>

/Pelle


Svara

Sv: Få fram datum

Postades av 2004-12-02 08:02:12 - Marcus Olsson

Sorry Pelle, men den funkar inte om dagen "D" är den 29 februari. Prova får du se... Men... din day()-funktion är snyggare.

/Marcus


Svara

Sv:Få fram datum

Postades av 2004-12-02 08:50:16 - Mikael Wedham

Sen anmärker jag (T-SQL polisen) på att man inte skall subtrahera datum, utan i så fall nästla en DATEADD() till...

/micke


Svara

Sv: Få fram datum

Postades av 2004-12-02 23:40:23 - Per Karlsson

Aaah, skottdagen tänkte jag inte på...
Ni har rätt båda två - men finns det egentligen något skäl att inte hantera datum direkt med - och +, förutom det rent stilistiska? Jag tycker rent av att det borde gå snabbare att inte använda dateadd eftersom datum internt representeras som två heltal (ett för datum och ett för tid).

/Pelle


Svara

Sv:Få fram datum

Postades av 2004-12-03 09:05:06 - Mikael Wedham

Visserligen just nu, men inte i .NET (och som alla inte vet så är SQL 2005 .NET integrerad...)

och dessutom om man testar lite, så är datumvärdet 1 (siffran ett konverterad till datum)

2 januari 1900, 1 januari 1900 eller 2 januari 1904 - allt beroende på inställningar.

man bör alltså inte alls förlita sig på att datum/tid är tal.

/micke


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 619
27 953
271 709
628
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies