>  기사  >  PHP 프레임워크  >  yii에서 데이터베이스에 연결하는 방법에는 여러 가지가 있습니다.

yii에서 데이터베이스에 연결하는 방법에는 여러 가지가 있습니다.

(*-*)浩
(*-*)浩원래의
2019-12-04 13:18:212831검색

yii에서 데이터베이스에 연결하는 방법에는 여러 가지가 있습니다.

PDO 방식(다중 테이블 연결 쿼리에 적합). ㅋㅋㅋ                        (권장 학습: yii 프레임워크 )

$sql = "";//原生态sql语句 
xx::model()->dbConnection->createCommand($sql)->execute();  非select语句(update、insert、delete)
xx::model()->dbConnection->createCommand($sql)->queryRow(); 查询select一条记录
xx::model()->dbConnection->createCommand($sql)->queryAll(); 查询select多条记录

$sql = "select a.*, count(b.role_id)as num from {{user_role}} a left join {{user}} b on a.id = b.role_id group by b.role_id order by a.id";
$user_role_info = UserRole::model()->dbConnection->createCommand($sql)->queryAll(); 
$this->render("list", array('user_role_info'=>$user_role_info));

예:

$sql = "select a.*, count(b.role_id)as num from slgo_user_role a left join slgo_user b on a.id = b.role_id group by b.role_id order by a.id";
$user_role_info = UserRole::model()->dbConnection->createCommand($sql)->queryAll(); 
$this->render("list", array('user_role_info'=>$user_role_info));

Active Record 방식

(1) New

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

기준 method

$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과 같은 메서드를 호출하여 이 작업을 수행할 수 있습니다.

이 방법은 매력적으로 보이지만 종종 혼란, 충돌 및 열 이름의 대소문자 구분과 같은 문제를 야기합니다.

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();

1. ActiveRecord를 잘 사용할 때, 즉 두 번째 방식에 비해 SQL 쿼리를 생성하지 않도록 하세요. 제 경험상 차이점에 크게 신경쓰실 필요는 없습니다. 시간과 성능면에서. 빅 데이터 쿼리의 경우 메모리 공간 측면에서 yii2의 toArray()를 사용하여 메모리 소비를 절약할 수 있습니다.

2. PDO에 비해 ActiveRecord의 장점은 편리함입니다.

하나는 SQL 문을 작성하는 것보다 ActiveRecord를 사용하는 것이 더 간단하고, 더 중요하게는 오류가 발생할 가능성이 적다는 것입니다.

둘째, SQL 문 외에도 매개변수 필터링, 바인딩 등 다양한 편의성을 제공합니다. 웹 개발을 하다보면 항상 이런 일이 발생하게 됩니다. SQL 문을 하나씩 작성하면 코드 재사용 정도가 높지 않고 어딘가에 필터링하는 것을 잊어버리기 쉬우므로 보안 위험이 발생합니다.

3. Yii2에는 이미 ActiveRecord보다 성능이 좋고 대체품으로 사용할 수 있는 Query가 있습니다. 물론 편리성과 효율성은 동전의 양면이며 ActiveRecord만큼 사용이 편리하지는 않습니다.

하지만 프로젝트에서 제 경험으로는 Query가 ActiveRecord보다 약간 덜 사용된다는 것입니다. 개인적으로 Query/ActiveQuery는 Yii2에 도입된 흥미로운 새 기능이라고 생각합니다.

4. 이전 기사에서는 ActiveRecord의 적용 시나리오에 대해 설명했습니다. PDO의 경우 명확하게 작성할 수 없는 한두 문장과 같이 보다 복잡한 SQL 작업에 사용하려면 PDO를 사용해야 합니다.

이 경우 ActiveRecord를 사용하여 빌드하는 것은 SQL을 직접 작성하는 것보다 복잡하지 않으므로 PDO 사용을 고려해 볼 수 있습니다. 하지만 내 생각에는 프로젝트에 사용된 SQL 문이 매우 복잡하면 DB 뷰나 저장 프로시저로 작성될 것이기 때문에 PDO는 많이 사용되지 않는다고 느낄 수 있다.

5. 더 높은 효율을 추구한다면 PDO를 너무 많이 사용하면 안 된다고 생각하는데, 나중에 유지보수가 매우 어렵습니다. 대신 SQL 쿼리 최적화, 인덱스 및 테이블 구조 최적화, 캐시 사용 등을 고려할 수 있습니다. 캐시를 사용하는 것이 가장 간단하고 직접적이며 효과적인 방법이라는 점은 언급할 가치가 있습니다.

6. 성능 문제를 너무 일찍 고려할 필요는 없습니다

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

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