Heim >Datenbank >MySQL-Tutorial >Was sind die MySQL-Datentypen?
MySQL-Datentypen umfassen: 1. Numerischer Typ; 2. Datums- und Uhrzeittyp; 3. Zeichenfolgentypen sind CHAR, VARCHAR, BINARY [Binärdatentyp], BLOB, TEXT [Texttyp], ENUM [Aufzählungstyp] und SET [Datenerfassung].
MySQL-Datentypen sind:
Die von MySQL unterstützten Datentypen sind in mehrere Kategorien unterteilt: numerische Typen, Datums- und Uhrzeittypen und Zeichenfolgentypen (Zeichen).
Hinweis:
Bei der Definition von Feldern verwenden wir häufig num int(10) ohne Vorzeichen. Das int(10) bedeutet nicht, dass das Feld 10 Längen speichert.
int(M) stellt das Format der digitalen Anzeige dar und ist nur gültig, wenn das Feldattribut auf Nullfüllung gesetzt ist.
eg:
tinyint(4) – Der tatsächlich gespeicherte Wert ist 2. Wenn Zerofill nicht angegeben ist, ist das Abfrageergebnis 2. Wenn Zerofill angegeben ist, ist das Abfrageergebnis 0002 und 0 wird zum Füllen verwendet die linke Seite;
Zerofill-Attribut:
Wenn das Feld das Zerofill-Attribut angibt, fügt MySQL automatisch das UNSIGNED-Attribut zum Feld hinzu.
Bei Beteiligung an Spaltenausdrücken oder UNION-Abfragen wird das ZEROFILL-Attribut ignoriert
Float:
Float(M,D): M ist die Anzahl der Ziffern in der Zahl , einschließlich des ganzzahligen Teils und des Dezimalteils; D ist der Dezimalteil , [D <= M-2]; 0,99 Float(2,1) – stellt eine ganze Zahl und eine Dezimalzahl dar, z. B.: 1.1
1 Ziffern mit
2Über den Standardwert: Der Standardwert muss ein konstantes Licht sein, keine Funktion oder ein Ausdruck. Ausnahme: Der Standardwert von Timestamp
kann verwendet werden.Wenn sich der Modus nicht im strengen Modus befindet, bestätigt das System anhand des Typs
Datums- und Uhrzeitformat:
DATATIME-Bereich: '1000-01-01 00:00:00'
bis '9999-12-31 23: 59:59'
. DATENbereich: '1000-01-01'
bis '9999-12-31'<span style="font-family: 宋体"></span> TIMESTAMP-Bereich: <code class="literal">'1970-01-01 00:00:01'
UTC bis '2038-01-19 03: 14:07'
'-838:59:59'
bis '838:59:59'<li>
<p> Jahrsbereich: Jahr(4) --- 1901~2155; Jahr(2) --- 00~99</p>
<p> TIMESTAMP: Die Zeitstempelspalte wird im gleichen Format wie die DATETIME-Spalte angezeigt. Mit anderen Worten: Die Anzeigebreite ist auf 19 Zeichen festgelegt und das Format ist „JJJJ-MM-TT HH:MM:SS“. </p>
<p> Der Datentyp TIMESTAMP bietet <span style="color: rgba(0, 0, 255, 1)">automatische Initialisierung und Aktualisierung</span>. Es kann jedoch nur eine Spalte mit dem Standardwert und der Aktualisierung angegeben werden als CURRENT_TIMESTAMP</p>
<p> 1. Automatische Initialisierung und automatische Aktualisierung, z. B.: ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP</p>
<p> 2. Nur automatische Initialisierung; z. B.: ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP</p>
<p> 3 . Nur automatische Aktualisierung; zB: ts TIMESTAMP DEFAULT 0 ON UPDATE CURRENT_TIMESTAMP</p>
<p> 4. Keine; zB: ts TIMESTAMP DEFAULT 0</p>
<h1> Der String-Typ ist CHAR, VARCHAR, BINARY [binärer Datentyp], TEXT [Texttyp], ENUM [Aufzählungstyp] und SET [Datenerfassung]. </h1>
<p class="sen_2"> Der Unterschied zwischen char und varchar: Der Unterschied in der Speicherlänge liegt in der maximalen Länge und darin, ob Leerzeichen beibehalten werden sollen. </p>
<p class="sen_2"> Char behält Leerzeichen bei, varchar behält keine Leerzeichen. </p>
<p class="sen_2"> </p>char ist 0~255; varchar ist 0~ 65535<p class="sen_2"><span style="color: rgba(255, 0, 0, 1)"></span></p> <p class="sen_2"><span style="color: rgba(255, 0, 0, 1)"><img src="https://img.php.cn/upload/article/000/000/052/abbcd334e0a9babc82ffd8a51c79262b-4.jpg" alt=""></span></p>
<p class="sen_2"> ENUM: <span style="color: rgba(255, 0, 0, 1)"><span style="color: rgba(255, 0, 0, 1)"></span>Eine Enumeration ist ein String-Objekt, das beim Erstellen einer Tabelle explizit einen Wert aus einer Liste zulässiger Werte für eine Spaltenspezifikation aufzählt. [</span>Wenn der eingefügte Wert nicht mit dem Wert der Liste übereinstimmen kann, ist der Standardwert der maximale Indexwert]<span style="line-height: 1.5"><span style="color: rgba(255, 0, 0, 1)"></span><pre class="brush:php;toolbar:false"> , ,</pre><pre class="programlisting">numbers ENUM(&#39;0&#39;,&#39;1&#39;,&#39;2&#39;)</pre><pre class="programlisting">mysql> INSERT INTO t (numbers) VALUES(2),(&#39;2&#39;),(&#39;3&#39;);mysql> SELECT * FROM t;+---------+
| numbers |
+---------+
| 1 |
| 2 |
| 2 |
+---------+</pre></span></p>
<p class="sen_2"> SET: <span style="line-height: 1.5"><span style="line-height: 1.5"></span>Eine Menge ist ein Objekt, das eine Zeichenfolge mit null oder mehr Werten haben kann. , die jeweils aus der Liste ausgewählt werden müssen, um den beim Erstellen der Tabelle angegebenen Wert zuzulassen. [</span>Wenn der eingefügte Wert nicht mit dem Wert der Liste übereinstimmen kann, ignoriert MYSQL den Wert, der nicht in der Liste vorhanden ist<span style="line-height: 1.5">]<span style="color: rgba(255, 0, 0, 1)"></span><pre class="brush:php;toolbar:false">1 CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));2 3 INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');</pre></span></p> Aus der Definition ist ersichtlich, dass der Unterschied zwischen ENUM und SET darin besteht value ist der Wert, der bei der Definition eines oder mehrerer davon angegeben wurde. Es gibt auch ein anderes Verhalten, wenn der eingefügte Wert nicht in der Liste vorhanden ist. <p class="sen_2"><span style="line-height: 1.5"></span></p>
<blockquote>Weitere verwandte kostenlose Lernempfehlungen: <p><strong></strong>MySQL-Tutorial<a href="https://www.php.cn/course/list/51.html" target="_blank"><strong></strong>(Video)</a><strong></strong></p>
</blockquote>
</li>
Das obige ist der detaillierte Inhalt vonWas sind die MySQL-Datentypen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!