Membahagikan jadual MySQL mengikut lajur datetime dengan matlamat satu partition setiap hari boleh menjadi pengoptimuman yang berharga teknik untuk set data yang besar. Walau bagaimanapun, memilih kaedah pembahagian yang betul adalah penting untuk prestasi yang berkesan.
Pendekatan pembahagian awal menggunakan partition HASH(hari(ftime)) 31 mempunyai had yang ketara. Pembahagian HASH tidak menggunakan pembahagian secara berkesan untuk lajur masa tarikh kerana ia tidak boleh menggunakan pemangkasan partition, yang akan mengecualikan partition yang tidak diperlukan daripada proses penilaian pertanyaan.
Pendekatan alternatif adalah untuk mencipta lajur INTEGER tambahan yang menyimpan nilai TO_DAYS(DATE()). Lajur Integer ini membolehkan pemangkasan, meningkatkan prestasi pertanyaan.
Kaedah pembahagian lain ialah pembahagian RANGE, yang memberikan fleksibiliti yang lebih besar. Dengan menentukan partition berdasarkan julat TO_DAYS(ftime) nilai, anda boleh memilih partition dengan tepat untuk tarikh tertentu. Sebagai contoh, contoh membahagikan ke dalam julat harian, memastikan pertanyaan seperti "SELECT * FROM raw_log_2011_4 WHERE ftime = '2011-04-03'" hanya mengakses partition untuk hari itu.
Kaedah pembahagian optimum bergantung pada keperluan khusus anda dan ciri jadual. Untuk senario di mana pemangkasan sekatan adalah penting, pendekatan lajur TO_DAYS() disyorkan. Jika anda memerlukan lebih fleksibiliti dalam pembahagian, pembahagian RANGE menawarkan penyelesaian yang berkuasa.
Atas ialah kandungan terperinci Berikut ialah beberapa pilihan untuk tajuk artikel anda, dengan mengingati format soalan yang anda minta: **Pilihan 1 (Terus dan terus terang):** * **Cara Membahagikan Jadual MySQL mengikut Datetime untuk Opti. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!