`
dcj3sjt126com
  • 浏览: 1880433 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Yii 框架里数据库操作详解-[增加、查询、更新、删除的方法 'AR模式']

    博客分类:
  • YII
 
阅读更多



    public function getMinLimit () {
        $sql = "...";
        $result = yii::app()->db->createCommand($sql);
        $query = $result->queryAll();
 
        return array (
                $query [0] ['max'], 
        );
    }

 

 

 



$connection=Yii::app()->db; 
$sql="SELECT u.account,i.* FROM sys_user as u left join user_info as i on u.id=i.user_id";
$rows=$connection->createCommand ($sql)->query();
foreach ($rows as $k => $v ){
    echo $v['add_time'];
}

 

 

======================================== 事务

$db = Yii::app()->db;
$dbTrans = $db->beginTransaction();


$dbTrans->commit();
$dbTrans->rollback();

 

 

 

========================================  分页

 


一般写法:
$criteria = new CDbCriteria;
$count = DnOnline::model()->count($criteria);
$pages = new CPagination($count);               
$pages->pageSize = 5;
$pages->applylimit($criteria);
$model = DnOnline::model()->findAll($criteria);

记得控制器里有个函数paginate($itemCount,$pageSize=null,$pageVar=null)
CDB写法:


$criteria = new CDbCriteria;
$sql = "SELECT * FROM USER";
$model= Yii::app()->db->createCommand($sql)->queryAll();
$pages = new CPagination(count($model));               
$pages->pageSize = 4;
$pages->applylimit($criteria);
$model=Yii::app()->db->createCommand($sql." LIMIT :offset,:limit");
$model->bindValue(':offset', $pages->currentPage*$pages->pageSize);
$model->bindValue(':limit', $pages->pageSize);
$model=$model->queryAll();



或者:

      $criteria = new CDbCriteria;
      $connection=Yii::app()->db; 
      $sql="SELECT u.account,i.* FROM sys_user as u left join user_info as i on u.id=i.user_id ";
      $model= Yii::app()->db->createCommand($sql)->queryAll();
      $pages = new CPagination(count($model));               
      $pages->pageSize = 4;
      $pages->applylimit($criteria);

      $model=Yii::app()->db->createCommand($sql." LIMIT :offset,:limit");
      $model->bindValue(':offset', $pages->currentPage*$pages->pageSize);
      $model->bindValue(':limit', $pages->pageSize);
      $model=$model->queryAll();


 

 

======================================== 一、查询数据集合 

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' and age=:age",array(':name'=>$name,'age'=>$age));    
该方法是根据主键查询一个集合,可以使用多个主键,如:  
findAllByPk(array(1,2));   


3、$admin=Admin::model()->findAllByAttributes($attributes,$condition,$params); 
该方法是根据条件查询一个集合,可以是多个条件,把条件放到数组里面,如:  
findAllByAttributes(array('username'=>'admin'));


4、$admin=Admin::model()->findAllBySql($sql,$params); 
该方法是根据SQL语句查询一个数组,如: 
findAllBySql("select *from admin whereusername=:name",array(':name'=>'admin')); 

========================================  二、查询对像 的方法  

1、$admin=Admin::model()->findByPk ($postID,$condition,$params); 
 根据主键查询出一个对象,如:findByPk(1); 

 

 

 

 


 2、$row=Admin::model()->find ($condition,$params); 
 根据一个条件查询出一组数据,可能是多个,但是他只返回第一行数据,如: 
find('username=:name',array(':name'=>'admin'));

 

      $userinfo=Userinfo::model()->find(array('condition'=>'user_id=:user_id','params'=>array(':user_id'=>$uid)));
      print_r($userinfo->user_id);

 

 


 3、$admin=Admin::model()->findByAttributes ($attributes,$condition,$params); 
 该方法是根据条件查询一组数据,可以是多个条件,把条件放到数组里面,他查询的也是第一条数据,如: 
findByAttributes(array('username'=>'admin'));


 4、$admin=Admin::model()->findBySql ($sql,$params); 
 该方法是根据SQL语句查询一组数据,他查询的也是第一条数据,如:  
findBySql("select *from admin whereusername=: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 isnot needed  
 
========================================  三、查询个数,判断查询是否有结果  

1、$n=Post::model()->count ($condition,$params); 
 该方法是根据一个条件查询一个集合有多少条记录,返回一个int型数字,如  
count("username=:name",array(":name"=>$username));   


 2、$n=Post::model()->countBySql ($sql,$params); 
 该方法是根据SQL语句查询一个集合有多少条记录,返回一个int型数字,如 
countBySql("select *from admin whereusername=:name",array(':name'=>'admin'));


 3、$exists=Post::model()->exists($condition,$params); 
 该方法是根据一个条件查询查询得到的数组有没有数据,如果有数据返回一个true,否则没有找到

 

 

 

        $sql = "select count(*) as count  from " . $this->tableName() . " where user_id = $userId";
        $query = $result->queryAll();
        $pageSize =10;
        $count = $query [0] ['count'];
        $pageCount = ceil($count / $pageSize);
        return $pageCount;



======================================== 四、添加的方法  
$admin=newAdmin;        
$admin->username=$username; 
$admin->password=$password; 
if($admin->save ()>0){ 
   echo "添加成功";  
}else{  
   echo "添加失败";  
}

 

 

 

$userLimit = new UserLimit();
$userLimit->item = 0.30000;
if($userLimit->insert (){

 

}


======================================== 五、修改的方法 

 


$userLimitRet = UserLimit::model()->findByPk (array (
                                'user_id' => $userId, 
                                'category_id' => $v 
                        ));
$userLimitRet->order = $order;

if (! $userLimitRet->update ()) {
}

 

 

 

 

 

$userAmount=userAmount::model()->findByPk ($userId);
$userAmount->credit=Yii::app()->request->getParam('credit',10000);
$ret = $userAmount->save ();

 

 

 


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 "修改失败";  

 

 

 

 

 

$ret = $this->updateAll (array (
                                'set' => $Set
                        ), " user_id in ( " . $userIds . " ) and category_id = " . $categoryId);

if($ret){
    return true;
}else {
    return false;
}

 

 


 2、Post::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=:nameandpassword=: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 "删除失败";  
}

分享到:
评论

相关推荐

    YII框架翻译整理最终稿 -

    4. **丰富的功能**:Yii 内置了多种实用功能,包括缓存机制、安全防护、数据库访问对象(DAO)、ActiveRecord 模式、I18N 和 L10N 支持等。 5. **清晰的文档**:Yii 提供详尽的文档,便于开发者快速学习和上手。 **...

    php YII框架数据库备份模块

    2. **ActiveRecord**:Yii的ORM(对象关系映射)层,使开发者能以面向对象的方式操作数据库记录,简化了数据库操作。 3. **Gii代码生成器**:Gii是一个自动生成代码的工具,可以帮助快速生成CRUD(创建、读取、更新...

    YII数据库操作大全

    在PHP开发领域,Yii框架是一个高效且灵活的开源框架,特别适合用于构建Web 2.0应用程序。在Yii中,数据库操作是核心功能之一,它提供了丰富的API...在实际开发中,开发者可以根据具体需求选择合适的方式来操作数据库。

    Yii框架数据库操作分享ppt

    Yii框架数据库操作分享ppt (Mac版,windows需转换格式)

    yii-advanced-app-2.0.10.tgz

    Yii 2 Advanced 应用程序框架是用于构建大型、复杂的 Web 应用程序的强大工具。这个版本是“yii-advanced-app-2.0.10.tgz”,它是一个压缩包,包含了 Yii 2 框架的高级应用模板,版本号为 2.0.10。这个版本可能包含...

    Yii框架详解

    Yii框架详解 Yii,全称为“Yet Another Inevitable Framework”,是PHP开发的一款高性能的、基于组件的Web应用开发框架。Yii的设计理念是简洁、高效和可扩展,它旨在提高开发速度并降低维护成本。本篇文章将深入...

    YII 2数据库迁移(Migrations) 使用教程

    在`safeUp()`方法中,可以使用Yii 2提供的数据库操作API来创建数据表,并定义字段。例如: ```php public function safeUp() { $tableOptions = null; if ($this->db->driverName === 'mysql') { // 设置表为...

    yii-advanced-app-2.0.36.tgz

    Yii 2 Advanced Application 是一个基于 Yii 2 框架的高级项目模板,适用于构建复杂的、多应用的 Web 应用程序。版本号 2.0.36 表示这是该框架的一个稳定版本,提供了许多改进和修复。这个 `.tgz` 文件是该模板的...

    yii-advanced-app-2.0.4

    开发者可以利用 Yii 的 MVC(模型-视图-控制器)模式和组件化设计来组织代码,同时框架提供了丰富的功能,如 ActiveRecord ORM(对象关系映射)、安全控制、缓存管理、AJAX 支持、表单验证等。 在开发过程中,Yii 2...

    yii1-ueditor-ext-1.1

    Yii1-UEditor-Ext-1.1 是一个专为Yii框架1.x版本设计的扩展插件,它将流行的富文本编辑器——百度UEditor整合到了Yii应用中。这个组件的目的是提供一个易于使用且功能丰富的文本编辑工具,使得开发者在处理用户内容...

    yii示例-下拉框-最新的yii框架

    - 使用Yii2的`asArray()`方法从数据库查询中获取数据,避免内存消耗。 - 避免在视图中写过多的业务逻辑,保持视图的简洁。 - 对于复杂表单,考虑使用Yii2的`GridView`或`DetailView`组件。 以上就是Yii2框架中...

    yii-basic-app-2.0.5.tgz

    Yii2框架的基本版(Basic App)是一个适合小型项目或者学习框架的简单启动模板,包括了基本的目录结构、配置文件、数据库迁移工具以及基本的前端和后端控制器。这个版本的更新意味着即使是初学者或小型项目也应该...

    yii-docs-2.0-zh-cn.tar.gz

    4. **ActiveRecord**:提供ORM(对象关系映射),使得数据库操作变得简单,支持ActiveRecord模式,让开发者能够以面向对象的方式操作数据库。 5. **安全特性**:内置了防止SQL注入、跨站脚本攻击(XSS)和其他常见...

    php最新框架YII框架

    2. 数据库支持:Yii支持多种数据库,包括MySQL、PostgreSQL、SQLite等,还提供了ActiveRecord模式,方便进行数据操作。 3. 缓存管理:内置了多种缓存策略,如文件缓存、APC缓存、Memcached和Redis,可以有效提升应用...

    yii-advanced-app-2.0.11.tgz

    "yii2.0.11"标签表明这是Yii 2框架的第11次次要版本更新。通常,这种版本更新会包含错误修复、性能优化和新功能的添加。对于开发者来说,保持框架的最新状态是很重要的,因为这能确保项目的稳定性和安全性。 在解压...

    yii-basic-app-2.0.15.tgz

    5. ORM(对象关系映射):Yii提供了ActiveRecord实现,使得数据库操作更加便捷,支持SQL查询构建和事务处理。 6. 错误和日志管理:提供强大的错误报告和日志记录功能,便于调试和维护。 7. 自动化测试:Yii支持...

    yii框架快速入门--(中文版)并附redmine-wiki对yii的解释

    Active Record是Yii的一个亮点,它允许开发者通过简单的对象操作来处理数据库记录,大大简化了数据操作。 3. **缓存管理**:Yii框架内置了多种缓存策略,包括页面缓存、片段缓存、数据缓存等,可以有效提升应用性能...

    Yii框架数据库查询、增加、删除操作示例

    Yii框架通过Active Record模式提供了一种更安全、更优雅的方式来处理数据库查询、增加和删除操作。它能够有效防止SQL注入问题,同时让数据库操作代码更加清晰易读。 如果想深入学习Yii框架或PHP相关知识,可以参考...

    yii框架中文手册教程

    1. 基于组件的设计:Yii框架采用组件化的设计模式,这意味着整个框架由多个可复用的组件构成,每个组件可以独立使用或配合其他组件完成特定的功能。这种设计让开发者能够灵活地组合和构建复杂的Web应用。 2. 高性能...

    Yii框架快速入门

    你可以直接通过对象属性来操作数据库记录,无需编写复杂的SQL语句。同时,Yii还支持数据访问对象(DAO)方式,为更复杂的数据操作提供了灵活性。 六、表单处理 Yii提供了强大的表单处理功能,包括自动验证和错误...

Global site tag (gtag.js) - Google Analytics