>PHP 프레임워크 >ThinkPHP >ThinkPHP: Db 클래스 및 모델의 올바른 사용

ThinkPHP: Db 클래스 및 모델의 올바른 사용

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼앞으로
2019-12-16 16:40:507329검색

ThinkPHP: Db 클래스 및 모델의 올바른 사용

ThinkPHP5.* 사용 시 Db 및 모델의 올바른 사용 자세를 이해하지 못하는 개발자가 많은 것으로 나타났습니다. 특히 5.1 버전에서는 다음과 같은 올바른 사용 자세를 사용하지 않을 경우 문제가 발생할 가능성이 높습니다. 곤경에 빠지다.

Db의 올바른 자세

다음은 Db 클래스의 공식 권장 사용법입니다(즉, 매번 정적 메서드 호출)

// 查询单个数据
Db::name('user')->where('id', 1)->find();
// 查询多个数据
Db::name('user')->where('id', '>', 1)->select();
// 写入新的数据
Db::name('user')->insert(['name' => '张三']);
// 更新数据
Db::name('user')->where('id', 1)->update(['name' => '李四']);
// 删除数据
Db::name('user')->delete(1);

많은 개발자는 코드를 단순화하기 위해 다음 코드를 사용하는 것을 좋아합니다.

단, 5.1에서는 아래 코드를 절대 사용하지 마세요!

// 错误的用法

$user = Db::name('user');
// 查询单个数据
$user->where('id', 1)->find();
// 查询多个数据
$user->where('id', '>', 1)->select();
// 写入新的数据
$user->insert(['name' => '张三']);
// 更新数据
$user->update(['name' => '李四']);
// 删除数据
$user->delete(1);

도우미 기능을 사용하는 것조차 여전히 권장되지 않습니다!

// 仍然是错误的用法

// 查询单个数据
db('user')->where('id', 1)->find();
// 查询多个数据
db('user')->where('id', '>', 1)->select();
// 写入新的数据
db('user')->insert(['name' => '张三']);
// 更新数据
db('user')->update(['name' => '李四']);
// 删除数据
db('user')->delete(1);

많은 개발자들이 왜 잘못된 사용법인지 궁금할 것입니다. 제가 사용해본 결과는 확실히 괜찮죠? 이것은 당신이 아직 함정에 빠지지 않았다는 것을 의미합니다.

실제 이유는 버전 5.1은 각 쿼리 후에 이전 쿼리 조건을 지우지 않기 때문입니다(5.0은 매번 조건을 지웁니다). 따라서 다음 사용법이 유효합니다.

$user = Db::name('user');
// 查询分数大于80分的用户总数
$count = $user->where('score', '>', 80)->count();
// 查询分数大于80分的用户数据
$user->select();

이것을 보고 나면 동일한 데이터베이스 쿼리 개체 인스턴스를 사용할 때 쿼리 조건이 항상 유지되고(이로 인해 후속 쿼리 조건이 혼동될 수 있음) 이후에 도우미 함수나 다중 작업을 사용하는 경우 이해해야 합니다. 수동 인스턴스화는 아래와 같이 수동으로 지우지 않는 한 동일한 객체 인스턴스가 됩니다.

$user = Db::name('user');
// 查询分数大于80分的用户总数
$count = $user->where('score', '>', 80)->count();
// 清除查询条件(但不包括排序或者字段等信息)
$user->removeOption('where');
// 查询所有用户数据 并按分数倒序排列 
$user->order('score', 'desc')->select();
// 清除所有查询条件
$user->removeOption();
// 查询分数等于100的用户
$user->where('score', 100)->select();

모범 사례: 매번 새로운 Db 정적 쿼리 사용

모델의 올바른 자세

모델의 디자인은 실제로 Db와 동일하며 기본적으로 수동으로 인스턴스화할 필요가 없습니다. .

// 写入新的数据
$user = User::create(['name' => '张三']);
// 更新数据
$user->update(['name' => '李四']);

// 查询单个数据
$user = User::get(1);
// 删除当前模型数据
$user->delete();

위 코드에서는 인스턴스화 코드를 사용하지 않고 모두 정적 메서드 작업을 사용합니다. 모델의 인스턴스화는 데이터를 쿼리하거나 쓸 때 시스템에 의해 자동으로 완료됩니다. 모델을 수동으로 인스턴스화하면 모델 인스턴스화를 반복하는 데 드는 비용이 발생합니다.

권장되지 않는 사용법:

$user = new User;
// 写入新的数据
$user->name = '张三';
$user->save();
$user = new User;
$user->find(1);
echo $user->name;

권장 사용법:

// 写入新的数据
User::create(['name' => '张三']);
$user = User::get(1);
echo $user->name;

따라서 모델을 수동으로 인스턴스화하지 마시고 모델 도우미 기능을 사용하는 것도 권장되지 않습니다.

모범 사례: 모델 쿼리 및 생성에 정적 메서드 사용

이제 Db 클래스 및 모델을 사용하는 올바른 자세를 이해하셨나요?

PHP 중국어 웹사이트에는 무료 ThinkPHP 입문 튜토리얼이 많이 있습니다. 누구나 배울 수 있습니다!

이 기사는 https://blog.thinkphp.cn/810719

에서 복제되었습니다.

위 내용은 ThinkPHP: Db 클래스 및 모델의 올바른 사용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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