>  기사  >  PHP 프레임워크  >  yii에서 데이터베이스를 작동하는 세 가지 방법

yii에서 데이터베이스를 작동하는 세 가지 방법

王林
王林원래의
2020-02-17 16:36:152329검색

yii에서 데이터베이스를 작동하는 세 가지 방법

1. Native SQL을 실행하는 PDO 방식

코드는 다음과 같습니다.

$sql = "";//原生态sql语句 
xx::model()->dbConnection->createCommand($sql)->execute();

2. Active Record 방식

(1) 새로운 방식

코드는 다음과 같습니다.

$post=new Post; 
$post->title='sample post'; 
$post->content='post body content'; 
$post->save();

(관련 튜토리얼 권장사항: yii 프레임워크)

(2) 기준 방법

$condition을 사용하여 더 복잡한 쿼리 조건을 지정할 수도 있습니다. 문자열을 사용하는 대신 $condition을 CDbCriteria의 인스턴스로 만들 수 있으며 이를 통해 WHERE에 국한되지 않는 조건을 지정할 수 있습니다.

코드는 다음과 같습니다.

$criteria=new CDbCriteria; 
$criteria->select='title';  // 只选择 'title' 列 
$criteria->condition='postID=:postID'; 
$criteria->params=array(':postID'=>10); 
$post=Post::model()->find($criteria);

CDbCriteria의 대안은 배열을 find 메소드에 전달하는 것입니다. 배열의 키와 값은 각각 기준의 속성 이름과 값에 해당합니다. 위의 예는 다음과 같이 다시 작성할 수 있습니다.

$post=Post::model()->find(array( 
    'select'=>'title', 
    'condition'=>'postID=:postID', 
    'params'=>array(':postID'=>10), 
));

쿼리 조건이 지정된 값으로 여러 열을 일치시키는 것인 경우 findByAttributes() 를 사용할 수 있습니다. $attributes 매개변수를 열 이름으로 인덱싱된 값의 배열로 만듭니다.

일부 프레임워크에서는 findByNameAndTitle과 같은 메서드를 호출하여 이 작업을 수행할 수 있습니다. 이 접근 방식은 매력적으로 보이지만 혼란, 충돌 및 열 이름의 대/소문자 구분과 같은 문제를 일으키는 경우가 많습니다.

3. Query Builder 방식

코드는 다음과 같습니다.

$user = Yii::app()->db->createCommand() 
    ->select('id, username, profile') 
    ->from('tbl_user u') 
    ->join('tbl_profile p', 'u.id=p.user_id') 
    ->where('id=:id', array(':id'=>$id)) 
    ->queryRow();

더 많은 프로그래밍 관련 내용을 알고 싶다면 php 중국어 홈페이지 Programming Tutorial 칼럼을 주목해주세요!

위 내용은 yii에서 데이터베이스를 작동하는 세 가지 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.