In thinkphp wird die m-Methode verwendet, um eine grundlegende Modellklasse zu instanziieren. Die m-Methode instanziiert ein Modellobjekt dynamisch, indem sie die Modellmethode direkt instanziiert, auch wenn die entsprechende Modelldatei nicht vorhanden ist (Modellname, Datentabellenpräfix, aktuell verwendete Datenbankverbindungsinformationen);".
Die Betriebsumgebung dieses Artikels: Windows 10-System, ThinkPHP5-Version, Dell G3-Computer.
Die M-Methode wird verwendet, um eine grundlegende Modellklasse zu instanziieren. Der Unterschied zur D-Methode ist:
1 Es ist nicht erforderlich, die Modellklasse anzupassen. und haben eine bessere Leistung;
2. Nach der Instanziierung können Sie nur Methoden in der Basismodellklasse aufrufen.
3 Sie können beim Instanziieren das Tabellenpräfix und die Datenbankverbindungsinformationen angeben.
Die Leistungsfähigkeit der D-Methode spiegelt sich darin wider, wie leistungsfähig die von Ihnen gekapselte benutzerdefinierte Modellklasse ist. Da jedoch die Basismodellklasse der neuen Version des ThinkPHP-Frameworks immer leistungsfähiger wird, wird die M-Methode immer leistungsfähiger praktischer als die D-Methode.
Das Aufrufformat der M-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 die verwenden Folgende Methode instanziiert eine Modellklasse, um Vorgänge auszuführen:
//实例化User模型 $User = M('User'); //执行其他的数据操作 $User->select();
Diese Methode ist die einfachste und effizienteste, da keine Modellklassen definiert werden müssen und daher projektübergreifende Aufrufe unterstützt. Der Nachteil besteht auch darin, dass es keine benutzerdefinierte Modellklasse gibt, sodass die entsprechende Geschäftslogik nicht geschrieben werden kann und nur grundlegende CURD-Operationen ausgeführt werden können.
$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 instanziieren
Die erste Möglichkeit zur Instanziierung besteht darin, dass es keine Definition der Modellklasse gibt, sodass es schwierig ist, einige zusätzliche Logikmethoden zu kapseln. In den meisten Fällen müssen Sie jedoch möglicherweise nur erweitern Dann können Sie die folgende Methode ausprobieren.
$User = M('CommonModel:User');
Die geänderte Verwendung entspricht tatsächlich:
$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.
Die M-Methode verfügt über drei Parameter. Der erste Parameter ist der Modellname (kann grundlegende Modellklassen und Datenbanken umfassen), und der zweite Parameter wird zum Festlegen des Präfixes verwendet die Datentabelle (lassen Sie es leer, um das Tabellenpräfix der aktuellen Projektkonfiguration zu übernehmen), und 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_');
bedeutet, die Model-Modellklasse zu instanziieren und die think_user-Tabelle in der db2-Datenbank zu betreiben.
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.
Empfohlenes Lernen: „PHP-Video-Tutorial“
Das obige ist der detaillierte Inhalt vonSo verwenden Sie die m-Methode in thinkphp5.0. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!