=======================================
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 "删除失败";
}
分享到:
相关推荐
4. **丰富的功能**:Yii 内置了多种实用功能,包括缓存机制、安全防护、数据库访问对象(DAO)、ActiveRecord 模式、I18N 和 L10N 支持等。 5. **清晰的文档**:Yii 提供详尽的文档,便于开发者快速学习和上手。 **...
2. **ActiveRecord**:Yii的ORM(对象关系映射)层,使开发者能以面向对象的方式操作数据库记录,简化了数据库操作。 3. **Gii代码生成器**:Gii是一个自动生成代码的工具,可以帮助快速生成CRUD(创建、读取、更新...
在PHP开发领域,Yii框架是一个高效且灵活的开源框架,特别适合用于构建Web 2.0应用程序。在Yii中,数据库操作是核心功能之一,它提供了丰富的API...在实际开发中,开发者可以根据具体需求选择合适的方式来操作数据库。
Yii框架数据库操作分享ppt (Mac版,windows需转换格式)
Yii 2 Advanced 应用程序框架是用于构建大型、复杂的 Web 应用程序的强大工具。这个版本是“yii-advanced-app-2.0.10.tgz”,它是一个压缩包,包含了 Yii 2 框架的高级应用模板,版本号为 2.0.10。这个版本可能包含...
Yii框架详解 Yii,全称为“Yet Another Inevitable Framework”,是PHP开发的一款高性能的、基于组件的Web应用开发框架。Yii的设计理念是简洁、高效和可扩展,它旨在提高开发速度并降低维护成本。本篇文章将深入...
在`safeUp()`方法中,可以使用Yii 2提供的数据库操作API来创建数据表,并定义字段。例如: ```php public function safeUp() { $tableOptions = null; if ($this->db->driverName === 'mysql') { // 设置表为...
Yii 2 Advanced Application 是一个基于 Yii 2 框架的高级项目模板,适用于构建复杂的、多应用的 Web 应用程序。版本号 2.0.36 表示这是该框架的一个稳定版本,提供了许多改进和修复。这个 `.tgz` 文件是该模板的...
开发者可以利用 Yii 的 MVC(模型-视图-控制器)模式和组件化设计来组织代码,同时框架提供了丰富的功能,如 ActiveRecord ORM(对象关系映射)、安全控制、缓存管理、AJAX 支持、表单验证等。 在开发过程中,Yii 2...
Yii1-UEditor-Ext-1.1 是一个专为Yii框架1.x版本设计的扩展插件,它将流行的富文本编辑器——百度UEditor整合到了Yii应用中。这个组件的目的是提供一个易于使用且功能丰富的文本编辑工具,使得开发者在处理用户内容...
- 使用Yii2的`asArray()`方法从数据库查询中获取数据,避免内存消耗。 - 避免在视图中写过多的业务逻辑,保持视图的简洁。 - 对于复杂表单,考虑使用Yii2的`GridView`或`DetailView`组件。 以上就是Yii2框架中...
Yii2框架的基本版(Basic App)是一个适合小型项目或者学习框架的简单启动模板,包括了基本的目录结构、配置文件、数据库迁移工具以及基本的前端和后端控制器。这个版本的更新意味着即使是初学者或小型项目也应该...
4. **ActiveRecord**:提供ORM(对象关系映射),使得数据库操作变得简单,支持ActiveRecord模式,让开发者能够以面向对象的方式操作数据库。 5. **安全特性**:内置了防止SQL注入、跨站脚本攻击(XSS)和其他常见...
2. 数据库支持:Yii支持多种数据库,包括MySQL、PostgreSQL、SQLite等,还提供了ActiveRecord模式,方便进行数据操作。 3. 缓存管理:内置了多种缓存策略,如文件缓存、APC缓存、Memcached和Redis,可以有效提升应用...
"yii2.0.11"标签表明这是Yii 2框架的第11次次要版本更新。通常,这种版本更新会包含错误修复、性能优化和新功能的添加。对于开发者来说,保持框架的最新状态是很重要的,因为这能确保项目的稳定性和安全性。 在解压...
5. ORM(对象关系映射):Yii提供了ActiveRecord实现,使得数据库操作更加便捷,支持SQL查询构建和事务处理。 6. 错误和日志管理:提供强大的错误报告和日志记录功能,便于调试和维护。 7. 自动化测试:Yii支持...
Active Record是Yii的一个亮点,它允许开发者通过简单的对象操作来处理数据库记录,大大简化了数据操作。 3. **缓存管理**:Yii框架内置了多种缓存策略,包括页面缓存、片段缓存、数据缓存等,可以有效提升应用性能...
Yii框架通过Active Record模式提供了一种更安全、更优雅的方式来处理数据库查询、增加和删除操作。它能够有效防止SQL注入问题,同时让数据库操作代码更加清晰易读。 如果想深入学习Yii框架或PHP相关知识,可以参考...
1. 基于组件的设计:Yii框架采用组件化的设计模式,这意味着整个框架由多个可复用的组件构成,每个组件可以独立使用或配合其他组件完成特定的功能。这种设计让开发者能够灵活地组合和构建复杂的Web应用。 2. 高性能...
你可以直接通过对象属性来操作数据库记录,无需编写复杂的SQL语句。同时,Yii还支持数据访问对象(DAO)方式,为更复杂的数据操作提供了灵活性。 六、表单处理 Yii提供了强大的表单处理功能,包括自动验证和错误...