Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk melaksanakan saas menggunakan php
Cara melaksanakan saas dengan php: 1. Buat bahagian belakang yang berasingan dan tetapkan akaun; , dan Pertanyaan menggunakan kaedah tetap; 4. Bungkus kaedah permintaan dan tambah "saas_id" dengan tetap.
Persekitaran pengendalian tutorial ini: sistem Windows 7, PHP versi 8.1, komputer DELL G3
Cara melaksanakan saas dengan php?
Mengenai PHP yang melaksanakan fungsi saas melalui sub-jadual
Biar saya bercakap tentang pemahaman saya tentang saas dahulu adalah setara dengan menganggap projek anda sendiri sebagai a Platform ini membenarkan sub-pengguna menggunakan fungsi platform dengan membahagikan akaun
Halaman Utama Cara pertama yang saya cuba adalah untuk membezakan setiap jadual dengan menambah saas_id Pada masa ini, jumlah data dalam setiap jadual saya ialah kira-kira 60,000 . , jika 10 pengguna tambahan digunakan, bilangannya akan menjadi 600,000 Sama ada ia sedang melihat atau mengubah suai, kecekapannya pasti tidak begitu tinggi, kerana selepas jumlah data latar belakang meningkat, ia juga dianggap membahagikan jadual mengikut tahun, jadi kita harus meninggalkan kaedah ini. Perkara seterusnya yang saya ingin fikirkan ialah Sub-pangkalan data, kerana ia adalah paling sesuai untuk sub-pangkalan data mengikut tahun dan sub-pengguna yang berbeza dalam Anzhao Walau bagaimanapun, ini disebabkan oleh pelbagai sebab kaedah tidak digunakan, dan sub-jadual telah digunakan pada akhirnya. Kerana fungsi projek ini telah dibangunkan, apa yang diperlukan sekarang mungkin adalah langkah berikut
Langkah pertama ialah menulis fungsi untuk membuka akaun Di sini anda boleh menulis bahagian belakang yang berasingan untuk memperuntukkan pembukaan akaun, atau tulis Atur cara kecil seperti h5 membenarkan pengguna untuk memohonnya sendiri Berikut adalah kaedah saya menjana pangkalan data dengan membahagikan jadual
$exist = Db::query('show tables like "ms_user' . $id . '"'); if (!$exist) { 方法1: $sql = <<<sql CREATE TABLE ms_user{$id} LIKE ms_user; sql; Db::execute($sql); 方法二: $sql = <<<sql CREATE TABLE ms_apply{$id} LIKE ms_apply; sql; Db::execute($sql); $sql = <<<sql INSERT ms_apply{$id} SELECT * FROM ms_apply; sql; Db::execute($sql); die; } }
Prinsip umum adalah untuk terlebih dahulu menyemak sama ada saas_id telah dihasilkan. jadual data, dalam kes untuk berjaga-jaga! Jika kandungan tidak perlu disalin ke jadual baharu, hanya salin struktur jadual terus mengikut kaedah 1. Contohnya, jika sesetengah jadual awam perlu menyalin kandungan awam ke jadual baharu, anda perlu menambah data ke pakej baharu mengikut langkah kedua kaedah 2.
Berikut ialah struktur jadual selepas pemisahan:
Langkah kedua ialah mengubah pangkalan data kaedah operasi tp menjadi kaedah awam untuk memudahkan penggantian Kod kelihatan seperti ini, tetapi ia sebenarnya menjimatkan banyak usaha
//db类 function dbs($table=''){ $table=$table.session('user.saas_id'); return Db::name($table); } function dba($table=''){ $table=$table.input('param.saas_id'); return Db::name($table); }
Selepas log masuk, bahagian belakang menggunakan sesi untuk menyimpan pertanyaan saas_id, yang menggunakan kaedah tetap untuk membuat pertanyaan, dan bahagian hadapan merangkum kaedah permintaan dan menambah medan saas_id
tetap Permintaan, jika anda ingin menggunakan model untuk menanyakan pangkalan data dan tidak menggunakan kelas Db, anda boleh hubungi saya.
…Saya akan mengemas kini di sini dahulu, dan saya akan mengemas kini kemudian jika anda tidak faham, anda boleh menghantar mesej kepada saya secara peribadi.
Pembelajaran yang disyorkan: "Tutorial Video PHP"
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan saas menggunakan php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!