ThinkPHP 데이터베이스 작업 뷰 쿼리, 하위 쿼리, 기본 쿼리
다음 튜토리얼 칼럼인 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











ThinkPHP 프로젝트를 실행하려면 다음이 필요합니다: Composer를 설치하고, 프로젝트 디렉터리를 입력하고 php bin/console을 실행하고, 시작 페이지를 보려면 http://localhost:8000을 방문하세요.

ThinkPHP에는 다양한 PHP 버전용으로 설계된 여러 버전이 있습니다. 메이저 버전에는 3.2, 5.0, 5.1, 6.0이 포함되며, 마이너 버전은 버그를 수정하고 새로운 기능을 제공하는 데 사용됩니다. 최신 안정 버전은 ThinkPHP 6.0.16입니다. 버전을 선택할 때 PHP 버전, 기능 요구 사항 및 커뮤니티 지원을 고려하십시오. 최상의 성능과 지원을 위해서는 최신 안정 버전을 사용하는 것이 좋습니다.

ThinkPHP Framework를 로컬에서 실행하는 단계: ThinkPHP Framework를 로컬 디렉터리에 다운로드하고 압축을 풉니다. ThinkPHP 루트 디렉터리를 가리키는 가상 호스트(선택 사항)를 만듭니다. 데이터베이스 연결 매개변수를 구성합니다. 웹 서버를 시작합니다. ThinkPHP 애플리케이션을 초기화합니다. ThinkPHP 애플리케이션 URL에 접속하여 실행하세요.

Laravel과 ThinkPHP 프레임워크의 성능 비교: ThinkPHP는 일반적으로 최적화 및 캐싱에 중점을 두고 Laravel보다 성능이 좋습니다. Laravel은 잘 작동하지만 복잡한 애플리케이션의 경우 ThinkPHP가 더 적합할 수 있습니다.

"개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법" 인터넷 기술의 급속한 발전으로 인해 웹 응용 프로그램은 많은 수의 동시 요청과 복잡한 비즈니스 논리를 처리하기 위한 요구 사항이 점점 더 높아졌습니다. 시스템 성능과 사용자 경험을 향상시키기 위해 개발자는 이메일 보내기, 파일 업로드 처리, 보고서 생성 등과 같이 시간이 많이 걸리는 작업을 수행하기 위해 비동기 작업을 사용하는 것을 종종 고려합니다. PHP 분야에서 널리 사용되는 개발 프레임워크인 ThinkPHP 프레임워크는 비동기 작업을 구현하는 몇 가지 편리한 방법을 제공합니다.

ThinkPHP 설치 단계: PHP, Composer 및 MySQL 환경을 준비합니다. Composer를 사용하여 프로젝트를 만듭니다. ThinkPHP 프레임워크와 종속성을 설치합니다. 데이터베이스 연결을 구성합니다. 애플리케이션 코드를 생성합니다. 애플리케이션을 실행하고 http://localhost:8000을 방문하세요.

ThinkPHP는 캐싱 메커니즘, 코드 최적화, 병렬 처리 및 데이터베이스 최적화와 같은 장점을 갖춘 고성능 PHP 프레임워크입니다. 공식 성능 테스트에 따르면 초당 10,000개 이상의 요청을 처리할 수 있으며 JD.com, Ctrip과 같은 대규모 웹 사이트 및 엔터프라이즈 시스템에서 실제 응용 프로그램으로 널리 사용됩니다.

ThinkPHP6 및 Swoole을 기반으로 한 RPC 서비스는 파일 전송 기능을 구현합니다. 소개: 인터넷이 발전하면서 일상 업무에서 파일 전송이 점점 더 중요해졌습니다. 본 글에서는 파일 전송의 효율성과 보안성을 향상시키기 위해 ThinkPHP6와 Swoole을 기반으로 한 RPC 서비스 기반의 파일 전송 기능의 구체적인 구현 방법을 소개하겠습니다. 우리는 ThinkPHP6을 웹 프레임워크로 사용하고 Swoole의 RPC 기능을 활용하여 서버 간 파일 전송을 달성할 것입니다. 1. 환경기준
