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 중국어 웹사이트의 기타 관련 기사를 참조하세요!