YII1 增、删、改、查数据库操作

增
//注意插入的时候 是用的new Post
$objectPost = new Post;
$objectPost->username = $username;
$objectPost->password = $password;
//或许
$objectPost->attributes = $arrNewData;
if($objectPost->save()){
$intPostId= $objectPost->primaryKey; //生成主键id
echo "添加成功";
}else{
echo "添加失败";
//在调试的状态下可以使用$objectPost->getErrors()来打印数据模型错误信息
}
删
根据条件删除集合 deleteAll($condition='',$params=array());
$condition = 'username=:name and password=:pass';
$params = array(':name'=>'www.aipanshi.com',':pass'=>'aipanshi.com');
//删除postid为这些的数据
$boolean = Post::model()->deleteAll('postid in("1,2,3")');
if($boolean > ){
echo "删除成功";
}else{
echo "删除失败";
}
```
根据主键删除一个集合 deleteByPk($pk,$condition='',$params=array())
$boolean = Post::model()->deleteByPk();
$boolean = Post::model()->deleteByPk(array(,),'username=:name',array(':name'=>'aipanshi.com'));
if($boolean > ){
echo "删除成功";
}else{
echo "删除失败";
}
改
根据条件 updateAll($attributes,$condition='',$params=array())
$attributes = array('username'=>'www.aipanshi.com','postsort'=>'');
$condition = 'status=:s';
$params = array(':s'=>);
$boolean = Post::model()->updateAll($attributes,$condition,$params);
if($boolean > ){
echo "修改成功";
}else{
echo "修改失败";
}
根据主键 updateByPk($pk,$attributes,$condition='',$params=array())
/**
* $pk主键 也可以是一个数组集合
* $attributes是要修改的字段的集合
* $condition条件
* $params传入的值
*/
$attributes = array('username'=>'www.aipanshi.com','password'=>'www.aipanshi.com');
$count =Post::model()->updateByPk(,$attributes);
$attributes2 = array('username'=>'www.aipanshi.com1','password'=>'www.aipanshi.com1');
$condition2 = 'username=:name';
$params2 = array(':name'=>'www.aipanshi.com');
$boolean =Post::model()->updateByPk(array(,),$attributes2,$condition2,$params2);
if($boolean > ){
echo "修改成功";
}else{
echo "修改失败";
}
自增和自减 updateCounters($counters,$condition='',$params=array());
//数据库中的post表根据条件username='www.aipanshi.com',查询出的所有结果status字段都自加1
$counters = array('status'=>);//-1自减
$condition = 'username=:name';
$params = array(':name'=>'www.aipanshi.com');
$boolean=Post::model()->updateCounters($counters,$condition,$params);
if($boolean > ){
echo "修改成功";
}else{
echo "修改失败";
}
查
查询指定字段
$res = KnowledgeAuthList::model()->find([
'select' => ['id'],
'condition' => 'auth_name=:auth_name',
'params' => [':auth_name'=>'基础']
]);
根据条件查询一个集合 findAll($condition='',$params=array())
$res=Post::model()->findAll("username=:name",array(":name"=>$username));
$res=Post::model()->findAll("username=:name and status=:s",array(":name"=>'jack',':s'=>));
$info = Post::model()->findAll("status = '1' ORDER BY postid DESC limit 10 ");
```
根据主键查询一个集合,可以使用多个主键 findAllByPk($pk,$condition='',$params=array())
$condition = "username like :name and status=:s";
$res=Post::model()->findAllByPk($ids,$condition,array(':name'=>$name,':s'=>));
$res=Post::model()->findAllByPk(array(,));
根据数组条件查询一个集合 findAllByAttributes($attributes,$condition='',$params=array())
$res=Post::model()->findAllByAttributes($attributes,$condition,$params);
$res=Post::model()->findAllByAttributes(array('username'=>'www.aipanshi.com'));
根据SQL语句查询一个数组 findAllBySql($sql,$params=array())
$res=Post::model()->findAllBySql($sql,$params);
$sql = "select * from tbl_post where username like :name";
$res=Post::model()->findAllBySql($sql,array(':name'=>'%Jack%'));
根据主键查询出一个对象 findByPk($pk,$condition='',$params=array())
$res=Post::model()->findByPk($postID,$condition,$params);
$res=Post::model()->findByPk();
根据条件查询,他只返回第一行数据find($condition='',$params=array())
$res=Post::model()->find('username=:name',array(':name'=>'www.aipanshi.com'));
根据数组条件查询,查询的也是第一条数据findByAttributes($attributes,$condition='',$params=array())
$res=Post::model()->findByAttributes(array('username'=>'www.aipanshi.com'));
根据SQL语句查询,查询的也是第一条数据 findBySql($sql,$params=array())
$sql = "select * from objectResult where username=:name";
$res=Post::model()->findBySql($sql,array(':name'=>'www.aipanshi.com'));
通过CDbCriteria类find查询出一个对象
$c=new CDbCriteria;
$c->select='username'; // 限制显示哪些字段
$c->condition='username=:username'; //一个查询条件用aCondition.多条件用addCondition
$c->params=array(":username=>'www.aipanshi.com'");
$c->order = "postsort DESC";
$c->limit = "";
$post=Post::model()->find($c);
多条件查询的语句
$c = new CDbCriteria;
$c->addCondition("postid=1"); //等同于 where postid = 1
$c->addInCondition('postid', array(,,,,)); //等同于 where postid IN (1,2,3,4,5,);
$c->addNotInCondition('postid', array(,,,,));//等同于 NOT IN (1,2,3,4,5,)
$c->addCondition('postid=1','OR');//等同于 OR而非AND
$c->addSearchCondition('username', 'www.aipanshi.com');//等同于 where name like '%www.aipanshi.com%'
$c->addBetweenCondition('postid', , );// 等同于 between 1 and 4
$c->compare('postid', ); //根据你的参数自动处理成addCondition或者addInCondition.
$c->compare('postid', array(,,)); //数组就会调用addInCondition
$c->select = 'postid,parentid,name'; //限制显示哪些字段
$c->join = 'xxx'; //连接表
$c->with = 'xxx'; //调用relations
$c->limit = ; //取1条数据,如果小于0,则不作处理
$c->offset = ; //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10
$c->order = 'xxx DESC,XXX ASC' ;//排序条件
$c->group = 'group 条件';
$c->having = 'having 条件 ';
$c->distinct = FALSE; //是否唯一查询
根据一个条件查询一个集合有多少条记录,返回一个int型数字count($condition='',$params=array())
$intCount=Post::model()->count("username=:name",array(":name"=>'aipanshi.com'));
根据SQL语句查询一个集合有多少条记录,返回int型 countBySql($sql,$params=array())
$sql = "select * from objectResult where username=:name";
$intCount=Post::model()->countBySql($sql,array(':name'=>'aipanshi.com'));
根据条件查询有无数据返回一个boolean exists($condition='',$params=array())
$boolExist=Post::model()->exists("name=:name",array(":name"=>'aipanshi.com'));
查询出复合条件的用户数组,指定了index以后,结果数组$users已经是用id做为主键的了
$posts = Post::model()->findAll(array('condition'=>'postsort > 18', 'index'=> 'id'));
摘自:http://www.aipanshi.com/post/type.html?name=yii
YII1 增、删、改、查数据库操作的更多相关文章
- 好用的SQL TVP~~独家赠送[增-删-改-查]的例子
以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化. 本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...
- iOS sqlite3 的基本使用(增 删 改 查)
iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...
- iOS FMDB的使用(增,删,改,查,sqlite存取图片)
iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...
- django ajax增 删 改 查
具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...
- ADO.NET 增 删 改 查
ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...
- MVC EF 增 删 改 查
using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...
- python基础中的四大天王-增-删-改-查
列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...
- 【转】Android 增,删,改,查 通讯录中的联系人
一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...
- Android 增,删,改,查 通讯录中的联系人
一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...
- 简单的php数据库操作类代码(增,删,改,查)
这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...
随机推荐
- HOOK IDT频繁蓝屏(Window 正确 HOOK IDT)
环境 win7x64 Microsoft Windows [版本 6.1.7601]也是一个朋友 HOOK IDT 测试 问我IDT为啥老是蓝屏.结果是因为swapgs问题. 如果你知道swapgs作 ...
- Sping boot和mybatis整合
在没有配置数据库时,注释这样@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class}) 接下来我们DataSourceA ...
- python接口自动化测试(c测试环境的准备)
接口测试的方式有很多,比如可以用工具(jmeter,postman)之类,也可以自己写代码进行接口测试,工具的使用相对来说都比较简单,重点是要搞清楚项目接口的协议是什么,然后有针对性的进行选择,甚至当 ...
- linux的基本操作(LAMP环境搭建)
LAMP 环境搭建 经过前部分章节的学习,你已经掌握了linux的基础知识了.但是想成为一名系统管理员恐怕还有点难度,因为好多单位招聘这个职位的时候都要求有一定的工作经验.然而真正的经验一天两天是学不 ...
- eclipse与hadoop-eclipse-plugin之间的版本对应关系
eclipse与hadoop-eclipse-plugin之间,版本互相不兼容,或者说,版本要求严格. 把hadoop-eclipse-plugin复制到eclipse的plugins目录下以后,如果 ...
- Tensorflow 的saved_model模块学习
saved_model模块主要用于TensorFlow Serving.TF Serving是一个将训练好的模型部署至生产环境的系统,主要的优点在于可以保持Server端与API不变的情况下,部署新的 ...
- linux文件系统变为只读解决
linux控制台显示文件系统变为只读,需输密码或者按ctrl+d结束 输入root密码后执行fsck -y /dev/sda1,fsck -y /dev/sda2和fsck -y /dev/sda3等 ...
- [redis] hiredis-vip 简单使用
redis的C语言client,有几个:https://redis.io/clients#c 支持cluster的只有一个唯品会的版本:https://github.com/vipshop/hired ...
- 图->有向无环图->拓扑排序
文字描述 关于有向无环图的基础定义: 一个无环的有向图称为有向无环图,简称DAG图(directed acycline graph).DAG图是一类较有向树更一般的特殊有向图. 举个例子说明有向无环图 ...
- qmp的简单使用
QMP是一种基于JSON格式的传输协议,可使用QMP与一个QEMU虚拟机实例进行交互,例如查询虚拟机的相关状态等,以下就QMP的使用进行简单介绍. 可以通过libvirt向一个运行的虚拟机发送qmp命 ...