


Detailed explanation of ThinkPHP functions: M method and R method
This article mainly introduces the M method and R method about the detailed explanation of ThinkPHP functions. It has a certain reference value. Now I share it with you. Friends in need can refer to it.
First of all, give it to everyone Introducing the detailed explanation of ThinkPHP functions: M method
M method is used to instantiate a basic model class. The difference from D method is:
1. No custom model class is required, reducing IO loading, good performance;
2. After instantiation, only methods in the basic model class (the default is the Model class) can be called;
3. You can Specify the table prefix, database and database connection information when instantiating; the power of the
D method is reflected in how powerful the custom model class you encapsulate is. However, with the new version of the basic model class of the ThinkPHP framework The functions are becoming more and more powerful, and the M method is more and more practical than the D method.
The calling format of the M method:
M('[Basic model name:]Model name','Data table prefix','Database connection information')
Let’s take a look at the specific uses of the M method:
1. Instantiate the basic model (Model) class
When no model is defined, we You can use the following method to instantiate a model class for operation:
//实例化User模型 $User = M('User'); //执行其他的数据操作 $User->select();
This method is the simplest and most efficient, because there is no need to define any model class, so Support cross-project calls. The disadvantage is also that there is no custom model class, so the relevant business logic cannot be written and only basic CURD operations can be completed.
$User = M('User');
is actually equivalent to:
$User = new Model('User');
means operating the think_user table. The M method also has a singleton function like the D method, and it will not be instantiated repeatedly if called multiple times. The model name parameter of the M method will be automatically converted to lowercase when converted into a data table, which means that ThinkPHP's data table naming specification is in all lowercase format.
2. Instantiate other public model classes
The first way to instantiate is because there is no definition of the model class, so it is difficult to encapsulate some additional logical methods, but In most cases, you may just need to extend some common logic, then you can try the following method.
$User = M('CommonModel:User');
The changed usage is actually equivalent to:
$User = new CommonModel('User');
Because of the system model Classes can be loaded automatically, so we do not need to manually import the class library before instantiation. The model class CommonModel must inherit Model. We can define some common logical methods in the CommonModel class, which eliminates the need to define specific model classes for each data table. If your project already has more than 100 data tables, most of them are basic For CURD operations, only some models have some complex business logic that needs to be encapsulated, so the combination of the first method and the second method is a good choice.
3. Pass in table prefix, database and other information
The M method has three parameters. The first parameter is the model name (can include the basic model class and database ), the second parameter is used to set the prefix of the data table (leave blank to take the table prefix of the current project configuration), and the third parameter is used to set the currently used database connection information (leave it blank to take the database connection of the current project configuration) Information), for example:
$User = M('db2.User','think_');
means instantiating the Model model class and operating the think_user table in the db2 database.
If the second parameter is left blank or not passed, it means using the data table prefix in the current project configuration. If the data table being operated does not have a table prefix, you can use:
$User = M('db1.User',null);
means instantiating the Model model class and operating the user table in the db1 database.
If the database you operate requires different user accounts, you can pass in the connection information of the database, for example:
$User = M('User','think_','mysql://user_a:1234@localhost:3306/thinkphp');
represents the basic model class Use Model, then operate the think_user table, use the user_a account to connect to the database, and the operating database is thinkphp.
The third connection information parameter can use DSN configuration or array configuration, and can even support configuration parameters.
For example, if
'DB_CONFIG'=>'mysql://user_a:1234@localhost:3306/thinkphp';
is configured in the project configuration file, you can use:
$User = M('User','think_','DB_CONFIG');
Basic model classes and databases can be used together, for example:
$User = M('CommonModel:db2.User','think_');
If you want to instantiate a hierarchical model, use the public model Class method, we can use:
M('UserLogic:User');
to instantiate UserLogic, although this does not make much sense, because you can use
D('User','Logic');
Achieve the same function.
Detailed explanation of ThinkPHP functions: R method
The R method is used to call the operation method of a certain controller, which is a further enhancement and supplement of the A method. See here for the usage of method A.
R method calling format:
R('[Project://][Group/]Module/Operation','Parameter','Controller layer name')
For example, we define an operation method as:
class UserAction extends Action { public function detail($id){ return M('User')->find($id); } }
那么就可以通过R方法在其他控制器里面调用这个操作方法(一般R方法用于跨模块调用)
$data = R('User/detail',array('5'));
表示调用User控制器的detail方法(detail方法必须是public类型),返回值就是查询id为5的一个用户数据。如果你要调用的操作方法是没有任何参数的话,第二个参数则可以留空,直接使用:
$data = R('User/detail');
也可以支持跨分组和项目调用,例如:
R('Admin/User/detail',array('5'));
表示调用Admin分组下面的User控制器的detail方法。
R('Admin://User/detail',array('5'));
表示调用Admin项目下面的User控制器的detail方法。
官方的建议是不要在同一层多太多调用,会引起逻辑的混乱,被公共调用的部分应该封装成单独的接口,可以借助3.1的新特性多层控制器,单独添加一个控制器层用于接口调用,例如,我们增加一个Api控制器层,
class UserApi extends Action { public function detail($id){ return M('User')->find($id); } }
然后,使用R方法调用
$data = R('User/detail',array('5'),'Api');
也就是说,R方法的第三个参数支持指定调用的控制器层。
同时,R方法调用操作方法的时候可以支持操作后缀设置C('ACTION_SUFFIX'),如果你设置了操作方法后缀,仍然不需要更改R方法的调用方式。
以上内容给大家分享了ThinkPHP函数详解之M方法和R方法,希望对大家有所帮助。
相关推荐:
The above is the detailed content of Detailed explanation of ThinkPHP functions: M method and R method. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...
