백엔드 개발 PHP 튜토리얼 ThinkPHP3.1新特性之命名范围的使用_PHP教程

ThinkPHP3.1新特性之命名范围的使用_PHP教程

Jul 13, 2016 am 10:24 AM
새로운 특성

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操作的时候出现问题,项目经理只需要合理的规划命名范围即可。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/825371.htmlTechArticleThinkPHP3.1的命名范围功能,给模型操作提供了一系列的(连贯操作)封装,让你更方便的查询和操作数据。下面我们就来具体了解下这一用...
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PHP 8.3 출시: 새로운 기능 한눈에 보기 PHP 8.3 출시: 새로운 기능 한눈에 보기 Nov 27, 2023 pm 12:52 PM

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

PHP8의 새로운 기능을 배우고 최신 기술에 대한 심층적인 이해를 얻을 수 있는 가이드 PHP8의 새로운 기능을 배우고 최신 기술에 대한 심층적인 이해를 얻을 수 있는 가이드 Dec 23, 2023 pm 01:16 PM

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

php8의 새로운 기능은 무엇입니까 php8의 새로운 기능은 무엇입니까 Sep 25, 2023 pm 01:34 PM

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

Go 언어의 새로운 기능 해석: 프로그래밍을 보다 효율적으로 만들기 Go 언어의 새로운 기능 해석: 프로그래밍을 보다 효율적으로 만들기 Mar 10, 2024 pm 12:27 PM

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

CSS3의 새로운 기능 개요: CSS3를 사용하여 전환 효과를 얻는 방법 CSS3의 새로운 기능 개요: CSS3를 사용하여 전환 효과를 얻는 방법 Sep 09, 2023 am 11:27 AM

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

PHP8.1에 도입된 새로운 Redis 확장 PHP8.1에 도입된 새로운 Redis 확장 Jul 07, 2023 pm 09:41 PM

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

CSS3의 새로운 기능 개요: CSS3를 사용하여 가로 중심 레이아웃을 구현하는 방법 CSS3의 새로운 기능 개요: CSS3를 사용하여 가로 중심 레이아웃을 구현하는 방법 Sep 09, 2023 pm 04:09 PM

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

CSS3의 새로운 기능 개요: CSS3 애니메이션 효과를 적용하는 방법 CSS3의 새로운 기능 개요: CSS3 애니메이션 효과를 적용하는 방법 Sep 09, 2023 am 09:15 AM

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

See all articles