배열 및 객체 기반 Yii 모델 쿼리 정보
이 글에서는 주로 Yii의 배열과 객체에 대한 모델 쿼리 기법을 소개하고 있으며, 필요한 친구들이 참고할 수 있도록 배열과 객체에 대한 Yii의 모델 쿼리 기법을 자세히 분석하고 있습니다. 배열 및 객체에 대한 모델 쿼리 기술을 기반으로 하는 쿼리 기술입니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
모델 게시물의 경우 개체 또는 개체 배열을 반환하는 다음 4가지 쿼리 메서드가 있습니다.//查找满足指定条件的结果中的第一行 find the first row satisfying the specified condition
$post=Post::model()->find($condition,$params);
//查找具有指定主键值的那一行 find the row with the specified primary key
$post=Post::model()->findByPk($postID,$condition,$params);
//查找具有指定属性值的行 find the row with the specified attribute values
$post=Post::model()->findByAttributes($attributes,$condition,$params);//未找到返回null
//通过指定的SQL 语句查找结果中的第一行 find the first row using the specified SQL statement
$post=Post::model()->findBySql($sql,$params);
find를 호출할 때 $condition 및 $params를 사용하여 쿼리 조건을 지정합니다. 여기서 $condition은 SQL 문의 WHERE 문자열일 수 있고 $params는 값이 $condation의 자리 표시자에 바인딩되어야 하는 매개 변수 배열입니다. 예: postID = 10
// find the row with postID=10 $post=Post::model()->find('postID=:postID', array(':postID'=>10));
조건 $condition이 SQL의 where 부분이라고 가정합니다. 매개변수는 매개변수를 통해 전달되지만 이름은 ":"으로 추가됩니다.
YII에는 쿼리를 구성하는 CDbCriteria 클래스가 있습니다. postId가 10인 제목을 쿼리하면 CdbCriteria는 다음과 같이 구성됩니다.
$criteria=new CDbCriteria; $criteria->select='title'; // only select the 'title' column $criteria->condition='postID=:postID'; $criteria->params=array(':postID'=>10); $post=Post::model()->find($criteria); // $params is not needed
CDbCriteria의 대안은 find 메소드에 배열을 전달하는 것입니다. 배열의 키와 값은 각각 기준의 속성 이름과 값에 해당합니다. 위의 예는 다음과 같이 다시 작성할 수 있습니다.
$post=Post::model()->find(array( 'select'=>'title', 'condition'=>'postID=:postID', 'params'=>array(':postID'=>10), ));
물론 findAll()
self::$_items[$type]=array(); $models=self::model()->findAll(array( 'condition'=>'type=:type', 'params'=>array(':type'=>$type), 'order'=>'position', ));
에도 적용됩니다. 쿼리 조건은 지정된 값이 열과 몇 번 일치하는지에 대한 것이며 findByAttributes()를 사용할 수 있습니다. $attributes 매개변수를 열 이름으로 인덱싱된 값의 배열로 만듭니다.
findByAttributes의 $attributes는 필드 이름입니다. 제목이 abc인지 쿼리하는 방법은 무엇입니까? 아래의Post::model()->findByAttributes(array('title'=>'abc'))
다른 방법을 참조하세요.
1. $admin=Admin::model()->findAll($condition,$params);
이 방법은 조건에 따라 컬렉션을 쿼리하는 것입니다. , 예:
findAll("username=:name",array(":name"=>$username));
findAllByPk($id,"name like ':name' 및 age =:age " ,array(':name'=>$name,'age'=>$age));
이 방법은 기본 키를 기반으로 컬렉션을 쿼리하는 것입니다. 여러 기본 키를 사용할 수 있습니다. as:
findAllByPk(array(1,2));
3, $ admin=Admin::model()->findAllByAttributes($attributes,$condition,$params);
이 방법은 여러 조건을 기반으로 컬렉션을 쿼리하는 것입니다. 조건을 다음과 같이 배열에 넣습니다.
findAllByAttributes(array('username'=>'admin'));
이 방법은 배열을 기반으로 쿼리하는 것입니다.
findAllBySql("select *from admin where username=:name",array(':name'=>'admin'));
1, $admin=Admin::model()->findByPk($postID,$condition,$params);
과 같은 쿼리 쌍 메서드 다음과 같은 기본 키를 기반으로 객체 쿼리:
findByPk(1);
조건은 여러 개가 있을 수 있지만
find('username=:name',array(':name'=>'admin'));
이 방법은 여러 조건이 될 수 있는 조건을 기반으로 데이터 세트를 쿼리하는 것입니다. 조건은 배열에 배치되며 그가 쿼리하는 첫 번째 데이터도
findByAttributes(array('username'=>'admin'));
이 방법은 SQL 문을 기반으로 데이터 세트를 쿼리하는 것입니다. 그가 쿼리하는 것은 다음과 같은 첫 번째 데이터 조각이기도 합니다.
findBySql("select *from admin where username=:name",array(':name'=>'admin'));
5. SQL을 얻는 방법을 조합한 다음 find
$criteria=new CDbCriteria; $criteria->select='username'; // only select the 'title' column $criteria->condition='username=:username'; $criteria->params=array(':username=>'admin'); $post=Post::model()->find($criteria); // $params is not needed
1. ()->count($condition,$params);
이 방법은 조건에 따라 컬렉션에 몇 개의 레코드가 있는지 쿼리하고 int 유형 숫자(예:
count("username=:name",array(":name"=>$username));
2, $n=)를 반환하는 것입니다. Post::model()->countBySql($sql,$params);
이 메소드는 SQL 문에 따라 세트에 몇 개의 레코드가 있는지 쿼리하는 것입니다.
countBySql("select *from admin where username=:name",array(':name'=>'admin'));
와 같은 int 유형 숫자를 반환합니다. 3, $exists=Post::model()->exists($condition,$params);
이 방법은 얻은 배열에 조건에 따라 데이터가 있는지 쿼리하고, 데이터가 있으면 true를 반환하고, 그렇지 않으면 찾을 수 없습니다
4. 메소드 추가
$admin=new Admin; $admin->username=$username; $admin->password=$password; if($admin->save()>0){ echo "添加成功"; }else{ echo "添加失败"; }
1. Post::model()->updateAll($attributes,$ Condition,$params);
$count = Admin::model()->updateAll(array('username'=>'11111','password'=>'11111'),'password=:pass',array(':pass'=>'1111a1')); if($count>0){ echo "修改成功"; }else{ echo "修改失败"; }
$count = Admin::model()->updateByPk(1,array('username'=>'admin','password'=>'admin')); $count = Admin::model()->updateByPk(array(1,2),array('username'=>'admin','password'=>'admin'),'username=:name',array(':name'=>'admin')); if($count>0){ echo "修改成功"; }else{ echo "修改失败"; }
$pk代表主键,可以是一个也可以是一个集合,$attributes代表是要修改的字段的集合,$condition代表条件,$params传入的值
3、Post::model()->updateCounters($counters,$condition,$params);
$count =Admin::model()->updateCounters(array('status'=>1),'username=:name',array(':name'=>'admin')); if($count>0){ echo "修改成功"; }else{ echo "修改失败"; }
array('status'=>1)代表数据库中的admin表根据条件username='admin',查询出的所有结果status字段都自加1
六、删除的方法
1、Post::model()->deleteAll($condition,$params);
$count = Admin::model()->deleteAll('username=:name and password=:pass',array(':name'=>'admin',':pass'=>'admin')); $id=1,2,3 deleteAll('id in(".$id.")');删除id为这些的数据 if($count>0){ echo "删除成功"; }else{ echo "删除失败"; }
2、Post::model()->deleteByPk($pk,$condition,$params);
$count = Admin::model()->deleteByPk(1); $count = Admin::model()->deleteByPk(array(1,2),'username=:name',array(':name'=>'admin')); if($count>0){ echo "删除成功"; }else{ echo "删除失败"; }
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
关于Yii Framework框架获取分类下面的所有子类的方法
위 내용은 배열 및 객체 기반 Yii 모델 쿼리 정보의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











PHP 배열에서 중복 요소를 제거하기 위해 foreach 루프를 사용하는 방법은 다음과 같습니다. 배열을 순회하고 요소가 이미 존재하고 현재 위치가 첫 번째 항목이 아닌 경우 삭제합니다. 예를 들어, 데이터베이스 쿼리 결과에 중복된 레코드가 있는 경우 이 방법을 사용하면 이를 제거하고 중복된 레코드가 없는 결과를 얻을 수 있습니다.

PHP에서 배열을 깊게 복사하는 방법에는 json_decode 및 json_encode를 사용한 JSON 인코딩 및 디코딩이 포함됩니다. array_map 및 clone을 사용하여 키와 값의 전체 복사본을 만듭니다. 직렬화 및 역직렬화를 위해 직렬화 및 역직렬화를 사용합니다.

PHP 배열 키 값 뒤집기 방법의 성능 비교는 array_flip() 함수가 대규모 배열(100만 개 이상의 요소)에서 for 루프보다 더 나은 성능을 발휘하고 시간이 덜 걸리는 것을 보여줍니다. 키 값을 수동으로 뒤집는 for 루프 방식은 상대적으로 시간이 오래 걸립니다.

MySQL 쿼리 결과 배열을 객체로 변환하는 방법은 다음과 같습니다. 빈 객체 배열을 만듭니다. 결과 배열을 반복하고 각 행에 대해 새 개체를 만듭니다. foreach 루프를 사용하여 각 행의 키-값 쌍을 새 개체의 해당 속성에 할당합니다. 개체 배열에 새 개체를 추가합니다. 데이터베이스 연결을 닫습니다.

PHP의 array_group_by 함수는 키 또는 클로저 함수를 기반으로 배열의 요소를 그룹화하여 키가 그룹 이름이고 값이 그룹에 속한 요소의 배열인 연관 배열을 반환할 수 있습니다.

PHP에서 배열 전체 복사를 수행하는 가장 좋은 방법은 json_decode(json_encode($arr))를 사용하여 배열을 JSON 문자열로 변환한 다음 다시 배열로 변환하는 것입니다. unserialize(serialize($arr))를 사용하여 배열을 문자열로 직렬화한 다음 새 배열로 역직렬화합니다. RecursiveIteratorIterator를 사용하여 다차원 배열을 재귀적으로 순회합니다.

PHP에서 배열은 순서가 지정된 시퀀스이며 요소는 인덱스로 액세스됩니다. 객체는 new 키워드를 통해 생성된 속성과 메서드가 있는 엔터티입니다. 배열 액세스는 인덱스를 통해 이루어지며, 객체 액세스는 속성/메서드를 통해 이루어집니다. 배열 값이 전달되고 객체 참조가 전달됩니다.

다차원 배열 정렬은 단일 열 정렬과 중첩 정렬로 나눌 수 있습니다. 단일 열 정렬은 array_multisort() 함수를 사용하여 열별로 정렬할 수 있습니다. 중첩 정렬에는 배열을 순회하고 정렬하는 재귀 함수가 필요합니다. 실제 사례로는 제품명별 정렬, 판매량 및 가격별 복합 정렬 등이 있습니다.
