ThinkPHP3.1新特性之命名范围的使用_PHP教程
ThinkPHP3.1的命名范围功能,给模型操作提供了一系列的(连贯操作)封装,让你更方便的查询和操作数据。下面我们就来具体了解下这一用法。
1.定义属性
要使用命名范围功能,主要涉及到模型类的_scope属性定义和scope连贯操作方法的使用。
我们首先定义_scope属性:
class NewsModel extends Model { protected $_scope = array( // 命名范围normal 'normal'=>array( 'where'=>array('status'=>1), ), // 命名范围latest 'latest'=>array( 'order'=>'create_time DESC', 'limit'=>10, ), ); }
_scope属性是一个数组,每个数组项表示定义一个命名范围,命名范围的定义格式为:
'命名范围标识'=>array( '属性1'=>'值1', '属性2'=>'值2', ... )
2.命名范围标识:可以是任意的字符串,用于标识当前定义的命名范围。
命名范围支持的属性包括:
where | 查询条件 |
field | 查询字段 |
order | 结果排序 |
table | 查询表名 |
limit | 结果限制 |
page | 结果分页 |
having | having查询 |
group | group查询 |
lock | 查询锁定 |
distinct | 唯一查询 |
cache | 查询缓存 |
每个命名范围的定义可以包括这些属性中一个或者多个。
3.方法调用
属性定义完成后,接下来就是使用scope方法进行命名范围的调用了,每调用一个命名范围,就相当于执行了命名范围中定义的相关操作选项。
调用某个命名范围
最简单的调用方式就直接调用某个命名范围,例如:
$Model = D('News'); // 这里必须使用D方法 因为命名范围在模型里面定义 $Model->scope('normal')->select(); $Model->scope('latest')->select();
生成的SQL语句分别是:
SELECT * FROM think_news WHERE status=1 SELECT * FROM think_news ORDER BY create_time DESC LIMIT 10
调用多个命名范围
也可以支持同时调用多个命名范围定义,例如:
$Model->scope('normal')->scope('latest')->select();
或者简化为:
$Model->scope('normal,latest')->select();
生成的SQL都是:
SELECT * FROM think_news WHERE status=1 ORDER BY create_time DESC LIMIT 10
如果两个命名范围的定义存在冲突,则后面调用的命名范围定义会覆盖前面的相同属性的定义。
如果调用的命名范围标识不存在,则会忽略该命名范围,例如:
$Model->scope('normal,new')->select();
上面的命名范围中new是不存在的,因此只有normal命名范围生效,生成的SQL语句是:
SELECT * FROM think_news WHERE status=1
4.默认命名范围
系统支持默认命名范围功能,如果你定义了一个default命名范围,例如:
protected $_scope = array( // 默认的命名范围 'default'=>array( 'where'=>array('status'=>1), 'limit'=>10, ), );
那么调用default命名范围可以直接使用:
$Model->scope()->select();
而无需再传入命名范围标识名
$Model->scope('default')->select();
虽然这两种方式是等效的。
命名范围调整
如果你需要在normal命名范围的基础上增加额外的调整,可以使用:
$Model->scope('normal',array('limit'=>5))->select();
生成的SQL语句是:
SELECT * FROM think_news WHERE status=1 LIMIT 5
当然,也可以在两个命名范围的基础上进行调整,例如:
$Model->scope('normal,latest',array('limit'=>5))->select();
生成的SQL是:
SELECT * FROM think_news WHERE status=1 ORDER BY create_time DESC LIMIT 5
自定义命名范围
又或者,干脆不用任何现有的命名范围,我直接传入一个命名范围:
$Model->scope(array('field'=>'id,title','limit'=>5,'where'=>'status=1','order'=>'create_time DESC'))->select();
这样,生成的SQL变成:
SELECT id,title FROM think_news WHERE status=1 ORDER BY create_time DESC LIMIT 5
5.与连贯操作混合使用
命名范围一样可以和之前的连贯操作混合使用,例如定义了命名范围_scope属性:
protected $_scope = array( 'normal'=>array( 'where'=>array('status'=>1), 'field'=>'id,title', 'limit'=>10, ), );
然后在使用的时候,可以这样调用:
$Model->scope('normal')->limit(8)->order('id desc')->select();
这样,生成的SQL变成:
SELECT id,title FROM think_news WHERE status=1 ORDER BY id desc LIMIT 8
如果定义的命名范围和连贯操作的属性有冲突,则后面调用的会覆盖前面的。
如果是这样调用:
$Model->limit(8)->scope('normal')->order('id desc')->select();
生成的SQL则是:
SELECT id,title FROM think_news WHERE status=1 ORDER BY id desc LIMIT 10
总结
命名范围功能的优势在于可以一次定义多次调用,并且在项目中也能起到分工配合的规范,避免开发人员在写CURD操作的时候出现问题,项目经理只需要合理的规划命名范围即可。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP8.3 출시: 새로운 기능 개요 기술이 계속 발전하고 변화가 필요함에 따라 프로그래밍 언어는 지속적으로 업데이트되고 개선됩니다. 웹 개발에 널리 사용되는 스크립팅 언어인 PHP는 개발자에게 더욱 강력하고 효율적인 도구를 제공하기 위해 지속적으로 개선되어 왔습니다. 최근 출시된 PHP 8.3 버전에는 오랫동안 기다려온 많은 새로운 기능과 개선 사항이 포함되어 있습니다. 이러한 새로운 기능에 대한 개요를 살펴보겠습니다. null이 아닌 속성의 초기화 이전 버전의 PHP에서는 클래스 속성에 명시적으로 값이 할당되지 않은 경우 해당 값은

최신 기술을 익히는 데 도움이 되는 PHP8의 새로운 기능에 대한 심층 분석입니다. 시간이 지남에 따라 PHP 프로그래밍 언어는 지속적으로 발전하고 개선되었습니다. 최근 출시된 PHP8 버전은 개발자에게 많은 흥미로운 새로운 기능과 개선 사항을 제공하여 개발 작업에 더 많은 편의성과 효율성을 제공합니다. 이 기사에서는 PHP8의 새로운 기능을 심층적으로 분석하고 이러한 최신 기술을 더 잘 익히는 데 도움이 되는 특정 코드 예제를 제공합니다. JIT 컴파일러 PHP8에는 JIT(Just-In-Time) 컴파일이 도입되었습니다.

php8의 새로운 기능에는 JIT 컴파일러, 유형 추론, 명명된 매개변수, 공용체 유형, 속성, 오류 처리 개선, 비동기 프로그래밍 지원, 새로운 표준 라이브러리 함수 및 익명 클래스 확장이 포함됩니다. 자세한 소개: 1. JIT 컴파일러, PHP8은 중요한 성능 향상을 제공하는 JIT 컴파일러를 도입하여 일부 고주파 실행 코드를 실시간으로 컴파일하고 최적화하여 실행 속도를 향상시킵니다. 개발자가 변수 등을 선언할 때 변수의 유형을 자동으로 추론할 수 있도록 유형 추론 기능을 도입합니다.

[Go 언어의 새로운 기능 해석: 프로그래밍을 보다 효율적으로 만들기 위해서는 구체적인 코드 예제가 필요합니다.] 최근 소프트웨어 개발 분야에서 Go 언어가 많은 주목을 받고 있으며, Go 언어의 단순하고 효율적인 디자인 개념이 점점 더 주목을 받고 있습니다. 개발자. 정적으로 유형이 지정된 프로그래밍 언어인 Go 언어는 개발 효율성을 향상하고 코드 작성 프로세스를 단순화하는 새로운 기능을 계속해서 도입하고 있습니다. 이 글에서는 Go 언어의 최신 기능에 대해 심층적으로 설명하고, 구체적인 코드 예제를 통해 이러한 새로운 기능이 제공하는 편리함을 경험하는 방법을 논의할 것입니다. 모듈형 개발(GoModules) 1부터 Go 언어

CSS3의 새로운 기능 개요: CSS3를 사용하여 전환 효과를 얻는 방법 CSS3는 많은 새로운 기능 중에서 가장 흥미롭고 실용적인 기능은 전환 효과입니다. 전환 효과는 상호 작용 중에 페이지를 더 부드럽고 아름답게 만들어 사용자에게 좋은 시각적 경험을 제공할 수 있습니다. 이 기사에서는 CSS3 전환 효과의 기본 사용법을 해당 코드 예제와 함께 소개합니다. 전환 속성 속성: 전환해야 하는 CSS 속성 전환 효과를 지정합니다.

PHP8.1에 도입된 새로운 Redis 확장 기능 인터넷의 급속한 발전으로 인해 많은 양의 데이터를 저장하고 처리해야 합니다. 데이터 처리의 효율성과 성능을 향상시키기 위해 캐싱은 필수적인 부분이 되었습니다. PHP 개발에서 고성능 키-값 스토리지 시스템인 Redis는 캐싱 및 데이터 스토리지 시나리오에 널리 사용됩니다. PHP에서 Redis를 사용하는 경험을 더욱 향상시키기 위해 PHP8.1에서는 새로운 Redis 확장 기능을 소개합니다. 이 기사에서는 이 확장 기능의 새로운 기능을 소개하고 제공할 것입니다.

CSS3의 새로운 기능 개요: CSS3를 사용하여 가로 중심 레이아웃을 구현하는 방법 웹 디자인 및 레이아웃에서 가로 중심 레이아웃은 일반적인 요구 사항입니다. 과거에는 이를 달성하기 위해 종종 복잡한 JavaScript 또는 CSS 트릭을 사용했습니다. 그러나 CSS3에는 가로 중심 레이아웃을 더 간단하고 유연하게 만드는 몇 가지 새로운 기능이 도입되었습니다. 이 기사에서는 CSS3의 몇 가지 새로운 기능을 소개하고 CSS3를 사용하여 가로 중심 레이아웃을 구현하는 방법을 보여주는 몇 가지 코드 예제를 제공합니다. 1. Flexbox를 사용하여 파일 레이아웃

CSS3의 새로운 기능 개요: CSS3 애니메이션 효과를 적용하는 방법 소개: 인터넷이 발전하면서 CSS3는 프런트엔드 개발에서 가장 일반적으로 사용되는 스타일 언어로 CSS2를 점차 대체해 왔습니다. CSS3는 많은 새로운 기능을 제공하며 그 중 가장 인기 있는 기능은 애니메이션 효과입니다. CSS3 애니메이션을 사용하면 웹 페이지에 멋진 대화형 효과를 추가하고 사용자 경험을 향상시킬 수 있습니다. 이 기사에서는 CSS3에서 일반적으로 사용되는 애니메이션 기능을 소개하고 관련 코드 예제를 제공합니다. 1. 트랜지션애니맷
