In thinkphp wird die M()-Methode zum Instanziieren einer Basismodellklasse verwendet. Nach der Instanziierung können nur Methoden in der Basismodellklasse (Standard ist die Modellklasse) aufgerufen werden. Die Syntax „M('[Basismodell name:] Modellname‘,‘Datentabellenpräfix‘,‘Datenbankverbindungsinformationen‘)“.
Die Betriebsumgebung dieses Tutorials: Windows 7-System, Thinkphp v5.1-Version, Dell G3-Computer. Die
M-Methode wird verwendet, um eine Basismodellklasse zu instanziieren.
erfordert keine benutzerdefinierten Modellklassen, reduziert die E/A-Belastung und bietet eine bessere Leistung;
Nur das Basismodell Nach der Instanziierung aufgerufene Methoden in der Modellklasse (Standard ist die Modellklasse);
Sie können beim Instanziieren das Tabellenpräfix, die Datenbank und die Datenbankverbindungsinformationen angeben Benutzerdefiniertes Modell, das Sie kapseln Egal wie leistungsfähig die Klasse ist: Da die Basismodellklasse der neuen Version des ThinkPHP-Frameworks immer leistungsfähiger wird, wird die M-Methode immer praktischer als die D-Methode.
M('[基础模型名:]模型名','数据表前缀','数据库连接信息')
Werfen wir einen Blick auf die spezifischen Verwendungszwecke der M-Methode:
1. Instanziieren Sie die Basismodellklasse (Modell)Wenn kein Modell definiert ist, können wir dies tun Verwenden Sie Folgendes: Die Methode instanziiert eine Modellklasse für den Betrieb: //实例化User模型
$User = M('User');
//执行其他的数据操作
$User->select();
$User = M('User');
ist eigentlich gleichbedeutend mit:
$User = new Model('User');
bedeutet, dass die think_user-Tabelle bedient wird. Die M-Methode verfügt ebenso wie die D-Methode über eine Singleton-Funktion und wird bei mehrmaligem Aufruf nicht wiederholt instanziiert. Der Modellnamensparameter der M-Methode wird bei der Konvertierung in eine Datentabelle automatisch in Kleinbuchstaben umgewandelt, was bedeutet, dass die Benennungsspezifikation für Datentabellen von ThinkPHP ausschließlich in Kleinbuchstaben vorliegt.
2. Andere öffentliche Modellklassen instanziierenDie erste Möglichkeit zur Instanziierung besteht darin, dass es keine Definition der Modellklasse gibt. Daher ist es schwierig, einige zusätzliche logische Methoden zu kapseln. In den meisten Fällen ist dies jedoch möglicherweise erforderlich Wenn Sie einige allgemeine Logik erweitern, können Sie die folgende Methode ausprobieren. $User = M('CommonModel:User');
$User = new CommonModel('User');
Da die Modellklassen des Systems automatisch geladen werden können, müssen wir die Klassenbibliothek vor der Instanziierung nicht manuell importieren. Die Modellklasse CommonModel muss Model erben. Wir können einige allgemeine logische Methoden in der CommonModel-Klasse definieren, wodurch die Notwendigkeit entfällt, für jede Datentabelle spezifische Modellklassen zu definieren. Wenn Ihr Projekt bereits über mehr als 100 Datentabellen verfügt, sind die meisten davon grundlegend. Für CURD-Operationen sind dies nur einige Modelle Da es sich um eine komplexe Geschäftslogik handelt, die gekapselt werden muss, ist die Kombination der ersten Methode und der zweiten Methode eine gute Wahl.
3. Übergeben Sie Tabellenpräfix, Datenbank und andere Informationen.Der erste Parameter ist der Modellname (kann grundlegende Modellklassen und Datenbanken umfassen), und der zweite Parameter wird zum Festlegen verwendet Datentabellenpräfix (lassen Sie es leer, um das Tabellenpräfix der aktuellen Projektkonfiguration zu übernehmen), der dritte Parameter wird verwendet, um die aktuell verwendeten Datenbankverbindungsinformationen festzulegen (lassen Sie es leer, um die Datenbankverbindungsinformationen der aktuellen Projektkonfiguration zu übernehmen), Beispiel: $User = M('db2.User','think_');
Wenn der zweite Parameter leer bleibt oder nicht übergeben wird, bedeutet dies, dass das Datentabellenpräfix in der aktuellen Projektkonfiguration verwendet wird. Wenn die betriebene Datentabelle kein Tabellenpräfix hat, können Sie Folgendes verwenden:
$User = M('db1.User',null);
bedeutet, dass das Modell instanziiert wird Modellklasse und Betriebs-db1-Benutzertabelle in der Datenbank.
Wenn die von Ihnen betriebene Datenbank unterschiedliche Benutzerkonten erfordert, können Sie beispielsweise die Verbindungsinformationen der Datenbank übergeben:
$User = M('User','think_','mysql://user_a:1234@localhost:3306/thinkphp');
bedeutet, dass die Basismodellklasse Model verwendet und dann die Tabelle think_user betreibt und das Konto user_a verwendet Stellen Sie eine Verbindung zur Datenbank her, und die Betriebsdatenbank ist thinkphp.
Der dritte Verbindungsinformationsparameter kann die DSN-Konfiguration oder Array-Konfiguration verwenden und sogar Konfigurationsparameter unterstützen.
Wenn Sie beispielsweise Folgendes konfigurieren:
'DB_CONFIG'=>'mysql://user_a:1234@localhost:3306/thinkphp';
in der Projektkonfigurationsdatei, können Sie Folgendes verwenden:
$User = M('User','think_','DB_CONFIG');
Grundlegende Modellklassen und Datenbanken können zusammen verwendet werden, zum Beispiel:
$User = M('CommonModel:db2.User','think_');
Wenn Sie ein hierarchisches Modell instanziieren möchten, Wenn wir die Methode der öffentlichen Modellklasse verwenden, können wir Folgendes verwenden:
M('UserLogic:User');
, um UserLogic zu instanziieren, obwohl dies nicht viel Sinn macht, da die gleiche Funktion mit
D('User','Logic');
erreicht werden kann.
【Verwandte Tutorial-Empfehlung:
Thinkphp Framework】
Das obige ist der detaillierte Inhalt vonSo verwenden Sie die m-Methode von thinkphp. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!