Heim > Backend-Entwicklung > PHP-Tutorial > Wie kann der korrekte Abruf ganzzahliger und numerischer Datentypen aus MySQL in PHP sichergestellt werden?

Wie kann der korrekte Abruf ganzzahliger und numerischer Datentypen aus MySQL in PHP sichergestellt werden?

Patricia Arquette
Freigeben: 2024-11-24 15:01:12
Original
1008 Leute haben es durchsucht

How to Ensure Correct Integer and Numeric Data Type Retrieval from MySQL in PHP?

So rufen Sie Ganzzahlen und Zahlen als typisierte Daten in PHP von MySQL ab

Es kann vorkommen, dass eine MySQL-Abfrage Zeichenfolgendatentypen zurückgibt für ganzzahlige und numerische Spalten in PHP, obwohl die Option „PDO::ATTR_STRINGIFY_FETCHES“ auf „false“ gesetzt ist. Diese Diskrepanz ist auf Probleme bei der Treiberimplementierung zurückzuführen.

Verwendung des mysqlnd-Treibers

Die Lösung liegt darin, sicherzustellen, dass der richtige Treiber verwendet wird, nämlich der mysqlnd-Treiber. Wenn Sie „php -i“ anzeigen, sollten Sie „mysqlnd“ explizit im Abschnitt „pdo_mysql“ erwähnt sehen. Wenn es nicht vorhanden ist, befolgen Sie diese Schritte, um es unter Ubuntu zu installieren:

  1. Entfernen Sie den nativen MySQL-Treiber:

    apt-get remove php5-mysql
    Nach dem Login kopieren
  2. Installieren Sie mysqlnd Treiber:

    apt-get install php5-mysqlnd
    Nach dem Login kopieren
  3. Neustart Apache2:

    service apache2 restart
    Nach dem Login kopieren

PDO-Einstellungen

Bestätigen Sie, dass die PDO-Einstellungen geeignet sind:

  • PDO::ATTR_EMULATE_PREPARES sollte falsch sein.
  • PDO::ATTR_STRINGIFY_FETCHES sollte sein false.

Zurückgegebene Werttypen

  • Gleitkommatypen (FLOAT, DOUBLE) werden als PHP-Floats zurückgegeben.
  • Ganzzahltypen (INTEGER, INT , SMALLINT, TINYINT, MEDIUMINT, BIGINT) werden als PHP zurückgegeben Ganzzahlen.
  • Festkommatypen (DECIMAL, NUMERIC) werden als Zeichenfolgen zurückgegeben.

Betrachten Sie beispielsweise das folgende zurückgegebene Objekt:

    object(stdClass)[915]
      public 'integer_col' => int 1
      public 'double_col' => float 1.55
      public 'float_col' => float 1.5
      public 'decimal_col' => string '1.20' (length=4)
      public 'bigint_col' => string '18446744073709551615' (length=20)
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann der korrekte Abruf ganzzahliger und numerischer Datentypen aus MySQL in PHP sichergestellt werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage