Rumah >pangkalan data >tutorial mysql >Bagaimana untuk menetapkan masa lalai dalam mysql

Bagaimana untuk menetapkan masa lalai dalam mysql

PHPz
PHPzasal
2023-04-20 10:10:422757semak imbas

MySQL ialah sistem pengurusan pangkalan data hubungan biasa. Apabila menggunakan MySQL, selalunya perlu menetapkan masa lalai. Kerana tetapan masa lalai boleh membantu meningkatkan ketepatan data. Jadi bagaimana untuk menetapkan masa lalai dalam MySQL? Artikel ini akan memperkenalkan anda kepada pengetahuan tentang tetapan masa lalai MySQL.

  1. Jenis masa MySQL

Dalam MySQL, terdapat banyak jenis masa, seperti DATE, TIME, DATETIME, YEAR, TIMESTAMP, dll. Jenis masa ini mewakili format masa yang berbeza. Berikut ialah pengenalan ringkas kepada jenis masa ini:

  • TARIKH: mewakili tarikh, dalam format YYYY-MM-DD>MASA: mewakili masa, dalam format HH: MM:SS ;
  • DATETIME: mewakili tarikh dan masa, dalam format YYYY-MM-DD HH:MM:SS
  • YEAR: mewakili tahun, dalam format YYYY; >
  • TIMESTAMP: Cap masa dalam format YYYY-MM-DD HH:MM:SS.
  • Tetapan masa lalai MySQL
  1. Dalam MySQL, anda boleh menggunakan kata kunci DEFAULT untuk menetapkan nilai lalai. Nilai lalai boleh menjadi pemalar, ungkapan atau fungsi. Anda boleh menggunakan fungsi CURRENT_TIMESTAMP apabila menetapkan masa lalai, yang mengembalikan tarikh dan masa masa semasa. Berikut ialah contoh:

Dalam contoh ini, jadual bernama contoh dicipta. Antaranya, nilai lalai lajur create_at ialah CURRENT_TIMESTAMP. Ini bermakna jika create_at tidak diberikan nilai semasa melaksanakan pernyataan INSERT, tarikh dan masa masa semasa akan diisi secara automatik.

CREATE TABLE `example` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
Selain menggunakan fungsi CURRENT_TIMESTAMP, anda juga boleh menggunakan fungsi NOW() untuk menetapkan masa lalai. Fungsi NOW() mempunyai fungsi yang sama seperti fungsi CURRENT_TIMESTAMP, kedua-duanya mengembalikan tarikh dan masa masa semasa. Contoh penggunaan fungsi NOW() untuk menetapkan masa lalai:

Perbezaan antara kod ini dan kod sebelumnya ialah fungsi NOW() digunakan dalam nilai lalai lajur create_at.

CREATE TABLE `example` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `created_at` TIMESTAMP DEFAULT NOW(),
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

Nota tentang tetapan masa lalai MySQL

  1. Apabila menetapkan masa lalai, anda perlu memberi perhatian kepada perkara berikut:

Jika anda menggunakan fungsi CURRENT_TIMESTAMP Tetapkan masa lalai Apabila baris dikemas kini, nilai lajur create_at akan dikemas kini secara automatik kepada masa semasa. Jika anda tidak mahu mengemas kini nilai lajur create_at, anda boleh menukar jenis lajur kepada jenis DATETIME

    Jika anda menggunakan fungsi NOW() untuk menetapkan masa lalai, nilai updated_at; lajur tidak akan dikemas kini secara automatik.
  • Jika anda menggunakan fungsi NOW() untuk menetapkan masa lalai dalam berbilang lajur pada masa yang sama, nilai lalai lajur ini adalah sama. Oleh itu, fungsi NOW() perlu digunakan pada setiap lajur secara berasingan.
  • Kesimpulan
  1. Artikel ini memperkenalkan pengetahuan yang berkaitan tentang tetapan masa lalai MySQL. Apabila benar-benar menggunakan MySQL, menetapkan masa lalai adalah sangat penting. Melalui pengenalan artikel ini, saya percaya anda telah memahami cara menetapkan masa lalai, dan boleh menjadi lebih selesa dalam aplikasi praktikal.

Atas ialah kandungan terperinci Bagaimana untuk menetapkan masa lalai dalam mysql. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn