백엔드 개발 PHP 튜토리얼 배열 및 객체 기반 Yii 모델 쿼리 정보

배열 및 객체 기반 Yii 모델 쿼리 정보

Jun 15, 2018 pm 01:58 PM
model 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 메소드가 쿼리 조건을 충족하는 행을 찾으면 데이터 테이블 행의 해당 열 값이 속성에 포함된 Post 인스턴스를 반환합니다. 그런 다음 echo $post->title;과 같은 일반 객체 속성처럼 로드된 값을 읽을 수 있습니다. 주어진 쿼리 기준을 사용하여 데이터베이스에서 아무 것도 발견되지 않으면 find 메소드는 null을 반환합니다.

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));
로그인 후 복사

2. $admin=Admin::model()->findAllByPk($postIDs,$condition,$params);

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'));
로그인 후 복사

4. $admin=Admin::model()->findAllBySql($sql,$params);

이 방법은 배열을 기반으로 쿼리하는 것입니다.

findAllBySql("select *from admin where username=:name",array(':name'=>'admin'));
로그인 후 복사

2.

1, $admin=Admin::model()->findByPk($postID,$condition,$params);

과 같은 쿼리 쌍 메서드 다음과 같은 기본 키를 기반으로 객체 쿼리:

findByPk(1);
로그인 후 복사

2 , $row=Admin::model()->find($condition,$params);

조건은 여러 개가 있을 수 있지만

find('username=:name',array(':name'=>'admin'));
로그인 후 복사

3과 같은 데이터의 첫 번째 행만 반환합니다. $admin=Admin::model()->findByAttributes($attributes,$condition,$params) ;

이 방법은 여러 조건이 될 수 있는 조건을 기반으로 데이터 세트를 쿼리하는 것입니다. 조건은 배열에 배치되며 그가 쿼리하는 첫 번째 데이터도

findByAttributes(array('username'=>'admin'));
로그인 후 복사

4, $admin=Admin입니다. ::model()->findBySql($sql,$params);

이 방법은 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
로그인 후 복사
3를 기반으로 객체를 쿼리합니다. 쿼리에 결과가 있는지 확인합니다

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 "添加失败";
}
로그인 후 복사
5. 메소드 수정

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 "修改失败";
}
로그인 후 복사
2. 게시물::model()->updateByPk($pk,$attributes,$condition,$params);

$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框架使用魔术方法实现跨文件调用的功能  

위 내용은 배열 및 객체 기반 Yii 모델 쿼리 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

foreach 루프를 사용하여 PHP 배열에서 중복 요소를 제거하는 방법은 무엇입니까? foreach 루프를 사용하여 PHP 배열에서 중복 요소를 제거하는 방법은 무엇입니까? Apr 27, 2024 am 11:33 AM

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

PHP 어레이 딥 카피(Array Deep Copy) 기술: 다양한 방법을 사용하여 완벽한 카피 달성 PHP 어레이 딥 카피(Array Deep Copy) 기술: 다양한 방법을 사용하여 완벽한 카피 달성 May 01, 2024 pm 12:30 PM

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

PHP 배열 키 값 뒤집기: 다양한 방법의 성능 비교 분석 PHP 배열 키 값 뒤집기: 다양한 방법의 성능 비교 분석 May 03, 2024 pm 09:03 PM

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

MySQL 쿼리 결과 배열을 객체로 변환하는 방법은 무엇입니까? MySQL 쿼리 결과 배열을 객체로 변환하는 방법은 무엇입니까? Apr 29, 2024 pm 01:09 PM

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

데이터 정렬에 PHP 배열 그룹화 기능 적용 데이터 정렬에 PHP 배열 그룹화 기능 적용 May 04, 2024 pm 01:03 PM

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

PHP 배열 심층 복사 모범 사례: 효율적인 방법 발견 PHP 배열 심층 복사 모범 사례: 효율적인 방법 발견 Apr 30, 2024 pm 03:42 PM

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

PHP에서 배열과 객체의 차이점은 무엇입니까? PHP에서 배열과 객체의 차이점은 무엇입니까? Apr 29, 2024 pm 02:39 PM

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

PHP 배열 다차원 정렬 연습: 간단한 시나리오부터 복잡한 시나리오까지 PHP 배열 다차원 정렬 연습: 간단한 시나리오부터 복잡한 시나리오까지 Apr 29, 2024 pm 09:12 PM

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

See all articles