Rumah > rangka kerja php > ThinkPHP > Bagaimana untuk menggunakan Phinx untuk pemindahan pangkalan data dalam ThinkPHP6?

Bagaimana untuk menggunakan Phinx untuk pemindahan pangkalan data dalam ThinkPHP6?

王林
Lepaskan: 2023-06-12 08:54:51
asal
1089 orang telah melayarinya

Dengan perkembangan pesat aplikasi web, pangkalan data, sebagai sebahagian daripada aplikasi, juga telah diberi kepentingan yang lebih tinggi. Bagi pembangun web, keselamatan, kebolehpercayaan dan kestabilan data pangkalan data adalah penting. Reka bentuk dan pengurusan jadual data juga merupakan bahagian penting dalam kerja pembangunan, jadi pemindahan data telah menjadi salah satu kaedah penting operasi pangkalan data.

Phinx ialah perpustakaan PHP yang membantu pembangun melaksanakan pemindahan pangkalan data dan pengurusan untuk aplikasi. Sebagai rangka kerja PHP yang popular, ThinkPHP6 juga menyediakan cara menggunakan Phinx, yang boleh memudahkan kerja pembangunan kami.

Artikel ini akan memperkenalkan kaedah menggunakan Phinx untuk pemindahan pangkalan data dalam rangka kerja ThinkPHP6.

  1. Pasang Phinx

Gunakan pertama Komposer untuk memasang Phinx dalam direktori projek:

composer require robmorgan/phinx
Salin selepas log masuk
  1. Konfigurasikan Phinx

Dalam ThinkPHP6, konfigurasi Phinx berada dalam fail config/phinx.php. Fail konfigurasi lalai boleh dijana melalui alat baris arahan:

vendor/bin/phinx init
Salin selepas log masuk

Selepas pelaksanaan, fail phinx.php akan dijana dalam direktori konfigurasi. Kita perlu mengkonfigurasi maklumat sambungan pangkalan data dan struktur direktori dan maklumat lain.

Contohnya, konfigurasikan maklumat sambungan pangkalan data:

return [
    'paths' => [
        'migrations' => '%%PHINX_CONFIG_DIR%%/db/migrations',
        'seeds' => '%%PHINX_CONFIG_DIR%%/db/seeds'
    ],
    'environments' => [
        'default_database' => 'development',
        'development' => [
            'adapter' => 'mysql',
            'host' => '127.0.0.1',
            'name' => 'thinkphp6',
            'user' => 'root',
            'pass' => '123456',
            'charset' => 'utf8',
        ]
    ]
];
Salin selepas log masuk
  1. Buat migrasi pangkalan data

Dalam ThinkPHP6, migrasi pangkalan data Phinx disimpan dalam direktori pangkalan data/migrasi . Kita boleh menggunakan arahan berikut untuk mencipta migrasi baharu:

vendor/bin/phinx create MyNewMigration
Salin selepas log masuk

Selepas melaksanakan arahan ini, fail migrasi baharu akan dibuat dalam pangkalan data/direktori migrasi.

Dalam Phinx, migrasi terbahagi kepada dua jenis: migrasi dan rollback. Penghijrahan mengandungi perubahan pada pangkalan data, pengembalian melakukan kebalikan daripada penghijrahan.

Sebagai contoh, kita perlu mencipta jadual pengguna:

use PhinxMigrationAbstractMigration;

class CreateUsersTable extends AbstractMigration
{
    /**
     * Change Method.
     *
     * More information on this method is available here:
     * http://docs.phinx.org/en/latest/migrations.html#the-change-method
     */
    public function change()
    {
        $table = $this->table('users');
        $table->addColumn('username', 'string', ['limit' => 50])
              ->addColumn('email', 'string', ['limit' => 100])
              ->addColumn('password', 'string', ['limit' => 255])
              ->addColumn('created_at', 'datetime')
              ->addColumn('updated_at', 'datetime')
              ->create();
    }
}
Salin selepas log masuk

Dalam kaedah change(), gunakan pembolehubah $table untuk membina struktur jadual dan gunakan kaedah addColumn() untuk tentukan jenis data untuk lajur dan sekatan yang berbeza. Akhir sekali, kaedah create() dipanggil untuk mencipta struktur jadual ke dalam pangkalan data.

  1. Lakukan penghijrahan pangkalan data

Kita boleh menggunakan arahan berikut untuk melakukan penghijrahan:

vendor/bin/phinx migrate
Salin selepas log masuk

Phinx akan melaksanakan perubahan dalam susunan penghijrahan dicipta. Jika semua migrasi berjaya dilaksanakan, Phinx akan mencipta jadual bernama phinxlog dalam pangkalan data untuk merekodkan sejarah migrasi.

Nota: Melakukan migrasi akan membuat perubahan pada pangkalan data, sila pastikan anda menyandarkan data anda untuk mengelakkan kehilangan data atau kebolehpulihan.

  1. Getar Balik Migrasi Pangkalan Data

Jika ralat berlaku atau perubahan perlu digulung semula, anda boleh menggunakan arahan berikut untuk melancarkan semula migrasi terakhir:

vendor/bin/phinx rollback
Salin selepas log masuk

Phinx akan Rollback migrasi terakhir yang berjaya dilaksanakan, jika wujud. Phinx akan menulis maklumat ke jadual phinxlog selepas melancarkan semula penghijrahan.

  1. Ringkasan

Di atas ialah proses pemindahan pangkalan data menggunakan Phinx dalam ThinkPHP6. Menggunakan Phinx boleh mengurangkan kerumitan dan risiko SQL tulisan tangan, menjadikan proses pemindahan pangkalan data lebih mudah dan lebih terkawal.

Semasa proses migrasi, kami boleh menggunakan ciri lanjutan Phinx, seperti pengisian data, pengesahan data dan sokongan untuk berbilang pangkalan data. Ciri-ciri ini boleh meningkatkan kebolehselenggaraan dan prestasi aplikasi.

Dalam pembangunan sebenar, kami mengesyorkan pemindahan dan pengurusan pangkalan data sebagai sebahagian daripada pembangunan pasukan untuk memastikan ketekalan dan kebolehpercayaan struktur data.

Atas ialah kandungan terperinci Bagaimana untuk menggunakan Phinx untuk pemindahan pangkalan data dalam ThinkPHP6?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan