>  기사  >  PHP 프레임워크  >  ThinkPHP 데이터베이스 작업 뷰 쿼리, 하위 쿼리, 기본 쿼리

ThinkPHP 데이터베이스 작업 뷰 쿼리, 하위 쿼리, 기본 쿼리

藏色散人
藏色散人앞으로
2021-02-02 15:25:183208검색

다음 튜토리얼 칼럼인 thinkphp에서는 ThinkPHP 데이터베이스 작업의 뷰 쿼리, 서브 쿼리, 네이티브 쿼리를 소개하겠습니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

View 쿼리

View 쿼리는 데이터베이스 뷰에 의존하지 않고 데이터베이스가 뷰를 지원할 필요가 없는 다중 테이블 쿼리를 구현할 수 있습니다. 예:

Db::view('User','id,name')
    ->view('Profile','truename,phone,email','Profile.user_id=User.id')
    ->view('Score','score','Score.user_id=Profile.id')
    ->where('score','>',80)
    ->select();

생성된 SQL 문은 다음과 유사합니다.

SELECT User.id,User.name,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user User 
INNER JOIN think_profile Profile ON Profile.user_id=User.id 
INNER JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80

  뷰 쿼리 주의사항 테이블 및 조인 메소드를 호출할 필요가 없으며 where 및 order 메소드 호출 시 테이블 이름을 추가하지 않고 필드 이름만 사용하면 됩니다.

INNER 조인 쿼리는 기본적으로 사용됩니다. 변경해야 하는 경우 다음을 사용할 수 있습니다.

Db::view('User','id,name')
    ->view('Profile','truename,phone,email','Profile.user_id=User.id','LEFT')
    ->view('Score','score','Score.user_id=Profile.id','RIGHT')
    ->where('score','>',80)
    ->select();

생성된 SQL 문은 다음과 유사합니다.

SELECT User.id,User.name,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user User 
LEFT JOIN think_profile Profile ON Profile.user_id=User.id 
RIGHT JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80

별칭을 사용할 수 있습니다.

Db::view('User',['id'=>'uid','name'=>'account'])
    ->view('Profile','truename,phone,email','Profile.user_id=User.id')
    ->view('Score','score','Score.user_id=Profile.id')
    ->where('score','>',80)
    ->select();

생성된 SQL 문은 다음과 같습니다. :

SELECT User.id AS uid,User.name AS account,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user User 
INNER JOIN think_profile Profile ON Profile.user_id=User.id 
INNER JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80

배열 메소드를 사용하여 테이블 이름과 별칭을 정의할 수 있습니다. 예:

Db::view(['think_user'=>'member'],['id'=>'uid','name'=>'account'])
    ->view('Profile','truename,phone,email','Profile.user_id=member.id')
    ->view('Score','score','Score.user_id=Profile.id')
    ->where('score','>',80)
    ->select();

생성된 SQL 문은 다음과 같습니다.

SELECT member.id AS uid,member.name AS account,Profile.truename,Profile.phone,Profile.email,Score.score 
FROM think_user member 
INNER JOIN think_profile Profile ON Profile.user_id=member.id 
INNER JOIN think_socre Score ON Score.user_id=Profile.id 
WHERE Score.score > 80

Subquery

먼저 하위 쿼리 SQL을 구성할 수 있습니다. 하위 쿼리를 구성하려면 다음 세 가지 방법을 사용하십시오.

1. select 메소드를 사용하세요

select 메소드의 매개변수가 false인 경우 쿼리가 수행되지 않고 구성된 SQL만 반환됨을 의미합니다. 예:

$subQuery = Db::table('think_user')    
->field('id,name')    
->where('id','>',10)    
->select(false);

생성된 하위 쿼리 결과는 다음과 같습니다.

SELECT `id`,`name` FROM `think_user` WHERE `id` > 10

2. fetchSql 메서드 사용

fetchSql 메서드는 쿼리를 수행하지 않고 생성된 SQL 문만 반환한다는 의미입니다. Select를 지원할 뿐만 아니라 모든 CURD 쿼리도 지원합니다.

$subQuery = Db::table('think_user')    
->field('id,name')    
->where('id','>',10)    
->fetchSql(true)    
->select();

에 의해 생성된 하위 쿼리 결과는

SELECT `id`,`name` FROM `think_user` WHERE `id` > 10

3입니다. buildSql을 사용하여 하위 쿼리를 생성하세요

$subQuery = Db::table('think_user')    
->field('id,name')    
->where('id','>',10)    
->buildSql();

생성된 하위 쿼리 결과는 다음과 같습니다.

( SELECT `id`,`name` FROM `think_user` WHERE `id` > 10 )

실제 쿼리 작업은 호출 후에 수행되지 않습니다. buildSql 메소드를 사용하고 이 쿼리에 대한 SQL 문을 생성한 다음(혼란을 피하기 위해 SQL 양쪽에 괄호가 추가됨) 후속 쿼리에서 이를 직접 호출합니다.

 처음 두 가지 방법을 사용할 때는 '괄호'를 직접 추가해야 한다는 점에 유의하세요.

그런 다음 하위 쿼리를 사용하여 새 쿼리를 생성합니다.

Db::table($subQuery.' a')    
->where('a.name','like','thinkphp')    
->order('id','desc')    
->select();

생성된 SQL 문은 다음과 같습니다.

SELECT * FROM ( SELECT `id`,`name` FROM `think_user` WHERE `id` > 10 ) a WHERE a.name LIKE 'thinkphp' ORDER BY `id` desc

4 클로저를 사용하여 하위 쿼리를 생성합니다

IN/NOT IN 및 EXISTS/ EXISTS와 같은 NOT 쿼리는 클로저를 하위 쿼리로 직접 사용할 수 있습니다. 예:

Db::table('think_user')    
->where('id','IN',function($query){        
$query->table('think_profile')->where('status',1)->field('id');
    })    
    ->select();

생성된 SQL 문은

SELECT * FROM `think_user` WHERE `id` IN ( SELECT `id` FROM `think_profile` WHERE `status` = 1 )
Db::table('think_user')    
->where(function($query){        
$query->table('think_profile')->where('status',1);
    },'exists')    
    ->find();

생성된 SQL 문은

SELECT * FROM `think_user` WHERE EXISTS ( SELECT * FROM `think_profile` WHERE `status`= 1 )

Native query

Db 클래스는 기본 SQL 쿼리를 지원합니다. 작업에는 주로 다음 두 가지 방법이 포함됩니다.

쿼리 방법

쿼리 방법은 SQL 쿼리 작업을 수행하는 데 사용됩니다. 데이터가 불법이거나 쿼리가 잘못된 경우 false를 반환하고, 그렇지 않으면 쿼리를 반환합니다. 결과 데이터 세트(select 방법과 동일)

사용예:

Db::query("select * from think_user where status=1");

 현재 분산 데이터베이스를 사용하고 읽기 및 쓰기 분리를 설정한 경우 쿼리 메서드는 항상 읽기 서버에서 실행되므로 SQL 문에 관계없이 쿼리 메서드는 읽기 작업에 해당합니다. 그렇죠.

execute 메소드

execute는 데이터를 업데이트하고 쓰는 SQL 작업에 사용되며, 데이터가 불법이거나 쿼리가 잘못된 경우 false를 반환하고, 그렇지 않으면 영향을 받은 레코드 수를 반환합니다.

사용 예:

Db::execute("update think_user set name='thinkphp' where status=1");

 현재 분산 데이터베이스를 사용하고 읽기-쓰기 분리를 설정한 경우 실행 메서드는 항상 쓰기 서버에서 실행되므로 실행 메서드는 SQL에 관계없이 쓰기 작업에 해당합니다. 성명.

매개변수 바인딩

은 물음표 자리 표시자 또는 명명된 자리 표시자를 포함하여 기본 쿼리에서 매개변수 바인딩 사용을 지원합니다. 예:

Db::query("select * from think_user where id=? AND status=?",[8,1]);
// 命名绑定
Db::execute("update think_user set name=:name where status=:status",['name'=>'thinkphp','status'=>1]);

위 내용은 ThinkPHP 데이터베이스 작업 뷰 쿼리, 하위 쿼리, 기본 쿼리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제