sql >> Database >  >> RDS >> Mysql

mysql , bigint of decimaal voor het opslaan van> 32 bit-waarden maar minder dan 64 bits

Naar mijn mening zou bigint beter zijn. Het wordt opgeslagen als een geheel getal dat MySQL native zal begrijpen zonder enige conversie, en daarom (denk ik) sneller zal zijn in het manipuleren. Je zou daarom verwachten dat MySQL iets efficiënter zal zijn als je bigint gebruikt.

Volgens deze handleidingpagina , worden de eerste 9 cijfers van uw nummer opgeslagen in een blok van vier bytes en de resterende cijfers (u hebt er maximaal 12 nodig) in een blok van twee bytes. Dat betekent dat uw kolom 6 bytes per rij in beslag neemt, in tegenstelling tot 8 bytes voor bigint. Ik zou willen voorstellen dat tenzij a) u een echt obsceen aantal rijen gaat opslaan, zodat de in beslag genomen ruimte een ernstig probleem is, en b) u de gegevens in kwestie heel weinig hoeft op te vragen, u ga met bigint.



  1. mysql-replicatie (TokuDB-replica):Kolom X van tabel 'database.table' kan niet worden geconverteerd van type 'varchar(Y)' naar type 'varchar(Y)'

  2. Eén, niet-unieke waarde uit een array verwijderen

  3. MySQL:Verleen **alle** rechten op database

  4. MySQL ERROR 1327 bij het doen van een INTO FROM