Zend_Date-Creation.xml 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 18427 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.date.creation">
  5. <title>Erstellen von Datumswerten</title>
  6. <para>
  7. <classname>Zend_Date</classname> unterstützt viele verschiedene Wege um eine neue Instanz
  8. von sich selbst zu erstellen. Da es verschiedene Notwendigkeiten gibt, werden die bequemsten
  9. Wege in diesem Kapitel gezeigt.
  10. </para>
  11. <sect2 id="zend.date.creation.actual">
  12. <title>Erstellen des aktuellen Datums</title>
  13. <para>
  14. Der einfachste Weg der Erstellung eines Datumsobjektes ist es ein aktuelles Datum zu
  15. erstellen. Man kann entweder eine neue Instanz mit <command>new Zend_Date()</command>
  16. erstellen, oder die bequemere statische Methode
  17. <methodname>Zend_Date::now()</methodname> verwenden wobei beide das aktuelle Datum als
  18. neue Instanz von <classname>Zend_Date</classname> zurückgeben. Das aktuelle Datum
  19. enthält immer das aktuelle Datum und die Zeit für die aktuell gesetzte Zeitzone.
  20. </para>
  21. <example id="zend.date.creation.actual.example-1">
  22. <title>Datum durch Instanz erstellen</title>
  23. <para>
  24. Datumserstellung durch Erzeugen einer neuen Instanz bedeutet das man keinen
  25. Parameter angeben muß. Natürlich gibt es mehrere Parameter die später beschrieben
  26. werden aber normalerweise ist das der einfachste und meist genutzte Weg um das
  27. aktuelle Datum als <classname>Zend_Date</classname> Instanz zu erhalten.
  28. </para>
  29. <programlisting language="php"><![CDATA[
  30. $date = new Zend_Date();
  31. ]]></programlisting>
  32. </example>
  33. <example id="zend.date.creation.actual.example-2">
  34. <title>Statische Erstellung eines Datums</title>
  35. <para>
  36. Machmal ist es einfacher eine statische Methode für die Erstellung eines Datums zu
  37. verwenden. Hierfür kann die <emphasis><methodname>now()</methodname></emphasis>
  38. Methode verwendet werden. Sie gibt eine neue Instanz von
  39. <classname>Zend_Date</classname> auf die gleiche Art und Weise zurück wie wenn man
  40. <command>new Zend_Date()</command> Verwenden würde. Es wird aber immer das aktuelle
  41. Datum zurückgegeben und das kann auch nur durch die Angabe von optionalen
  42. Parametern geändert werden.
  43. </para>
  44. <programlisting language="php"><![CDATA[
  45. $date = Zend_Date::now();
  46. ]]></programlisting>
  47. </example>
  48. </sect2>
  49. <sect2 id="zend.date.creation.database">
  50. <title>Erstellen von Datumswerten von einer Datenbank</title>
  51. <para>
  52. Datenbanken werden oft verwendet um Datumswerte zu speichern. Aber das Problem ist, das
  53. jede Datenbank Ihre Datumswerte in einem anderen Weg ausgibt. <emphasis>MsSQL</emphasis>
  54. Datenbanken verwenden eine etwas andere Standardausgabe von Datumswerten als
  55. <emphasis>MySQL</emphasis> Datenbanken. Aber zur Vereinfachung macht es
  56. <classname>Zend_Date</classname> sehr simpel ein Datum von einem Datumswert einer
  57. Datenbank zu erstellen.
  58. </para>
  59. <para>
  60. Natürlich kann jeder Datenbank gesagt werden das Sie die Ausgabe einer definierten
  61. Spalte in einen speziellen Wert konvertiert. Zum Beispiel können ein
  62. <emphasis>datetime</emphasis> Wert so konvertiert werden das ein Minutenwert ausgegeben
  63. wird. Aber das benötigt viel Zeit und oft müssen Datumswerte auf eine andere Art und
  64. Weise bearbeitet werden als bei der Erstellung der Datenbankabfrage gedacht wurde.
  65. </para>
  66. <para>
  67. Deswegen gibt es einen schnellen und einen bequemen Weg ein Datum von Datenbankwerten zu
  68. erstellen.
  69. </para>
  70. <example id="zend.date.creation.database.example-1">
  71. <title>Schnelle Erstellung eines Datums von Datumswerten einer Datenbank</title>
  72. <para>
  73. Von allen Datenbanken ist bekannt das Sie Abfragen so schnell wie möglich
  74. bearbeiten. Sie wurden erstellt um schnell zu arbeiten und zu antworten. Der
  75. Schnellste Weg um Datumswerte zu bearbeiten ist es aus der Datenbank Unit Timestamps
  76. zu erhalten. Alle Datenbanken speichern Datumswerte intern als Timestamps (nicht
  77. Unix Timestamps). Das bedeutet das die Zeit für die Erstellung eines Timestamps
  78. durch eine Abfrage viel kleiner ist als die Konvertierung in ein spezielles Format.
  79. </para>
  80. <programlisting language="php"><![CDATA[
  81. // SELECT UNIX_TIMESTAMP(my_datetime_column) FROM my_table
  82. $date = new Zend_Date($unixtimestamp, Zend_Date::TIMESTAMP);
  83. ]]></programlisting>
  84. </example>
  85. <example id="zend.date.creation.database.example-2">
  86. <title>Bequeme Erstellung eines Datums von Datumswerten einer Datenbank</title>
  87. <para>
  88. Die Standardausgabe von allen Datenbanken ist leicht unterschiedlich selbst wenn
  89. diese auf den ersten Blick gleich ausschauen. Aber alle sind Teil des
  90. <acronym>ISO</acronym> Standards und durch Ihn beschrieben. Deshalb liegt der
  91. einfachste Weg ein Datum zu erstellen in der Verwendung von
  92. <constant>Zend_Date::ISO_8601</constant>. Datenbanken von denen bekannt ist das
  93. Sie durch <constant>Zend_Date::ISO_8601</constant> erkannt werden sind zum
  94. Beispiel <emphasis>MySQL</emphasis> und <emphasis>MsSQL</emphasis>. Aber alle
  95. Datenbanken können eine <acronym>ISO-8601</acronym> Repräsentation von Datumsspalten
  96. ausgeben. <acronym>ISO-8601</acronym> hat den großen Vorteil das es menschlich
  97. lesbar ist. Der Nachteil ist das <acronym>ISO-8601</acronym> mehr Zeit zur
  98. Berechnung benötigt als ein einfacher Unix Timestamp. Es soll auch erwähnt werden
  99. das Unix Timestamps nur für Datumswerte nach dem 1 Jänner 1970 unterstützt werden.
  100. </para>
  101. <programlisting language="php"><![CDATA[
  102. // SELECT datecolumn FROM my_table
  103. $date = new Zend_Date($datecolumn, Zend_Date::ISO_8601);
  104. ]]></programlisting>
  105. </example>
  106. </sect2>
  107. <sect2 id="zend.date.creation.array">
  108. <title>Erstellung eines Datums von einem Array</title>
  109. <para>
  110. Datumswerte können auch durch die Verwendung eines Arrays erstellt werden. Das ist ein
  111. einfacher und leichter Weg. Die verwendeten Array Schlüssel sind:
  112. </para>
  113. <itemizedlist mark='opencircle'>
  114. <listitem>
  115. <para>
  116. <emphasis>day</emphasis>: Tag des Datums als Zahl
  117. </para>
  118. </listitem>
  119. <listitem>
  120. <para>
  121. <emphasis>month</emphasis>: Monat des Datums als Zahl
  122. </para>
  123. </listitem>
  124. <listitem>
  125. <para>
  126. <emphasis>year</emphasis>: Vollständiges Jahr des Datums
  127. </para>
  128. </listitem>
  129. <listitem>
  130. <para>
  131. <emphasis>hour</emphasis>: Stunde des Datums
  132. </para>
  133. </listitem>
  134. <listitem>
  135. <para>
  136. <emphasis>minute</emphasis>: Minute des Datums
  137. </para>
  138. </listitem>
  139. <listitem>
  140. <para>
  141. <emphasis>second</emphasis>: Sekunde des Datums
  142. </para>
  143. </listitem>
  144. </itemizedlist>
  145. <example id="zend.date.creation.array.example">
  146. <title>Erstellen eines Datums durch ein Array</title>
  147. <para>
  148. Normalerweise wird ein komplettes Datumsarray für die Erstellung einer neuen Instanz
  149. des Datums angegeben werden. Aber wenn nicht alle Werte angegeben werden, werden die
  150. nicht angegebenen Arraywerte genullt. Das bedeutet das wenn z.B. keine Stunde
  151. angegeben wird, die Stunde <emphasis>0</emphasis> verwendet wird.
  152. </para>
  153. <programlisting language="php"><![CDATA[
  154. $datearray = array('year' => 2006,
  155. 'month' => 4,
  156. 'day' => 18,
  157. 'hour' => 12,
  158. 'minute' => 3,
  159. 'second' => 10);
  160. $date = new Zend_Date($datearray);
  161. ]]></programlisting>
  162. <programlisting language="php"><![CDATA[
  163. $datearray = array('year' => 2006, 'month' => 4, 'day' => 18);
  164. $date = new Zend_Date($datearray);
  165. ]]></programlisting>
  166. </example>
  167. </sect2>
  168. </sect1>