Heim > PHP-Framework > Denken Sie an PHP > So verwenden Sie die m-Methode in thinkphp5.0

So verwenden Sie die m-Methode in thinkphp5.0

WBOY
Freigeben: 2022-02-15 14:39:57
Original
2702 Leute haben es durchsucht

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);".

So verwenden Sie die m-Methode in thinkphp5.0

Die Betriebsumgebung dieses Artikels: Windows 10-System, ThinkPHP5-Version, Dell G3-Computer.

So verwenden Sie die m-Methode in thinkphp5.0

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('[基础模型名:]模型名','数据表前缀','数据库连接信息')
Nach dem Login kopieren

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();
Nach dem Login kopieren

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');
Nach dem Login kopieren

ist eigentlich gleichbedeutend mit:

$User = new Model('User');
Nach dem Login kopieren

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');
Nach dem Login kopieren

Die geänderte Verwendung entspricht tatsächlich:

$User = new CommonModel('User');
Nach dem Login kopieren

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_');
Nach dem Login kopieren

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);
Nach dem Login kopieren

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');
Nach dem Login kopieren

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';
Nach dem Login kopieren

in der Projektkonfigurationsdatei, können Sie Folgendes verwenden:

$User = M('User','think_','DB_CONFIG');
Nach dem Login kopieren

Grundlegende Modellklassen und Datenbanken können zusammen verwendet werden, zum Beispiel:

$User = M('CommonModel:db2.User','think_');
Nach dem Login kopieren

Wenn Sie ein hierarchisches Modell instanziieren möchten, Wenn wir die Methode der öffentlichen Modellklasse verwenden, können wir Folgendes verwenden:

M('UserLogic:User');
Nach dem Login kopieren

, um UserLogic zu instanziieren, obwohl dies nicht viel Sinn macht, da die gleiche Funktion mit

D('User','Logic');
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage