M 메소드는 기본 모델 클래스를 인스턴스화하는 데 사용됩니다.
1. 인스턴스화 후 모델 클래스를 사용자 정의할 필요가 없습니다.
2. , 기본 모델 클래스에서만 메서드를 호출할 수 있습니다(기본값은 Model 클래스).
3. 인스턴스화 시 테이블 접두사, 데이터베이스 및 데이터베이스 연결 정보를 지정할 수 있습니다.
D 메서드의 성능이 반영됩니다. 캡슐화 된 사용자 정의 모델 클래스는 얼마나 강력합니까? 그러나 ThinkPHP 프레임워크 새 버전의 기본 모델 클래스가 점점 더 강력해지면서 M 방법이 D 방법보다 점점 더 실용적이 되고 있습니다.
M 메소드 호출 형식 :
M('[기본 모델명:]모델명','데이터 테이블 접두사','데이터베이스 연결 정보')
구체적인 용도를 살펴보겠습니다. M 메소드 중 :
1. 기본 모델(Model) 클래스 인스턴스화
모델이 정의되지 않은 경우 다음 메소드를 사용하여 작업용 모델 클래스를 인스턴스화할 수 있습니다.
//实例化User模型 $User = M('User'); //执行其他的数据操作 $User->select();
이 방법은 모델 클래스를 정의할 필요가 없어 프로젝트 간 호출을 지원하므로 가장 간단하고 효율적입니다. 단점은 커스텀 모델 클래스가 없어 관련 비즈니스 로직을 작성할 수 없고 기본적인 CURD 연산만 완료할 수 있다는 점이다.
$User = M('User');
은 실제로 다음과 같습니다.
$User = new Model('User');
은 think_user 테이블을 작동한다는 의미입니다. M 메서드에도 D 메서드와 마찬가지로 싱글톤 함수가 있으며, 여러 번 호출해도 반복적으로 인스턴스화되지 않습니다. M 메소드의 모델 이름 매개변수는 데이터 테이블로 변환될 때 자동으로 소문자로 변환됩니다. 이는 ThinkPHP의 데이터 테이블 이름 지정 사양이 모두 소문자 형식임을 의미합니다.
2. 다른 공용 모델 클래스 인스턴스화
첫 번째 인스턴스화 방법은 모델 클래스에 대한 정의가 없기 때문에 일부 추가적인 논리적 메소드를 캡슐화하기는 어렵지만 대부분의 경우 다음으로 일부 일반 논리를 확장해야 할 경우 다음 방법을 시도해 볼 수 있습니다.
$User = M('CommonModel:User');
사용 방법은 다음과 같습니다.
$User = new CommonModel('User');
시스템의 모델 클래스가 자동으로 로드될 수 있으므로 인스턴스화하기 전에 클래스 라이브러리를 수동으로 가져올 필요가 없습니다. 모델 클래스 CommonModel은 Model을 상속해야 합니다. CommonModel 클래스에서 몇 가지 일반적인 논리적 메서드를 정의할 수 있으므로 각 데이터 테이블에 대해 특정 모델 클래스를 정의할 필요가 없습니다. 프로젝트에 이미 100개 이상의 데이터 테이블이 있는 경우 대부분은 기본입니다. CURD 작업의 경우 일부 모델에만 있습니다. 캡슐화해야 하는 복잡한 비즈니스 논리이므로 첫 번째 방법과 두 번째 방법을 조합하는 것이 좋습니다.
3. 들어오는 테이블 접두사, 데이터베이스 및 기타 정보
M 메서드에는 세 가지 매개 변수가 있습니다. 첫 번째 매개 변수는 모델 이름(기본 모델 클래스 및 데이터베이스를 포함할 수 있음)입니다. 두 개의 매개변수는 데이터 테이블의 접두사를 설정하는 데 사용되며(현재 프로젝트 구성의 테이블 접두사를 가져오려면 공백으로 놔두세요), 세 번째 매개변수는 현재 사용되는 데이터베이스 연결 정보를 설정하는 데 사용됩니다(공란으로 놔두어 가져오려면) 현재 프로젝트 구성의 데이터베이스 연결 정보) 예를 들어
$User = M('db2.User','think_');
은 Model 모델 클래스를 인스턴스화하고 db2 데이터베이스에서 think_user 테이블을 운영하는 것을 의미합니다.
두 번째 파라미터가 비어 있거나 전달되지 않은 경우 현재 프로젝트 구성에서 데이터 테이블 접두사를 사용한다는 의미입니다. 운영 중인 데이터 테이블에 테이블 접두사가 없는 경우
$User = M('db1.User',null);을 사용할 수 있습니다.
인스턴스화 Model 모델 클래스를 나타내며 db1 데이터베이스에서 사용자 테이블을 운영합니다.
운영하는 데이터베이스에 다른 사용자 계정이 필요한 경우 데이터베이스의 연결 정보를 전달할 수 있습니다. 예:
$User = M('User','think_','mysql://user_a:1234@localhost:3306/thinkphp');
은 Model을 사용하여 기본 모델 클래스를 나타내고 user_a 계정을 사용합니다. think_user 테이블을 운영하기 위해 데이터베이스에 연결하기 위해 운영 데이터베이스는 thinkphp입니다.
세 번째 연결 정보 매개변수는 DSN 구성 또는 어레이 구성을 사용할 수 있으며 구성 매개변수를 지원할 수도 있습니다.
예를 들어 프로젝트 구성 파일에서
'DB_CONFIG'=>'mysql://user_a:1234@localhost:3306/thinkphp';
을 구성하는 경우 다음을 사용할 수 있습니다.
$User = M('User','think_','DB_CONFIG');
기본 모델 클래스와 데이터베이스를 함께 사용할 수 있습니다. 예:
$User = M('CommonModel:db2.User','think_');
공개 모델 클래스를 사용하여 계층적 모델을 인스턴스화하려면
M('UserLogic:User');
을 사용하여 UserLogic을 인스턴스화할 수 있지만 이는 별 의미가 없습니다. ,
D('User','Logic');
을 사용하면 동일한 기능을 얻을 수 있기 때문입니다.
위 내용은 내용의 측면을 포함하여 ThinkPHP 기능: M 메소드에 대한 자세한 설명을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.