Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

Каква е спецификацията на формата на шестнадесетичната дата в SQL сървъра?

DATE тип се съхранява вътрешно като 3-байтово цяло число, представляващо броя на дните от 1 януари 0001.

Шестнадесетичната стойност, която имате, е във формат little-endian, така че ще трябва да я обърнете към big-endian, преди да можете да я използвате в C# DateTime изчисления:

string hexString = "38320B00";

// convert the first 6 characters to bytes and combine them into an int
// we can ignore the final two characters because the DATE type is a
// 3-byte integer - the most-significant-byte should always be zero
int days = byte.Parse(hexString.Substring(0, 2), NumberStyles.HexNumber)
    | byte.Parse(hexString.Substring(2, 2), NumberStyles.HexNumber) << 8
    | byte.Parse(hexString.Substring(4, 2), NumberStyles.HexNumber) << 16;

DateTime dt = new DateTime(1, 1, 1).AddDays(days);

Console.WriteLine(dt);    // 12/12/2009 00:00:00



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Какво е доверена връзка?

  2. Може ли Microsoft да съхранява полета с три стойности в един бит?

  3. Сортиране на първичен ключ

  4. SQL Server 2016:Винаги криптиран

  5. Как NULLIF() работи в SQL Server