1. //注意插入的时候 是用的new Post
  2. $objectPost = new Post;
  3. $objectPost->username = $username;
  4. $objectPost->password = $password;
  5. //或许
  6. $objectPost->attributes = $arrNewData;
  7. if($objectPost->save()){
  8. $intPostId= $objectPost->primaryKey; //生成主键id
  9. echo "添加成功";
  10. }else{
  11. echo "添加失败";
  12. //在调试的状态下可以使用$objectPost->getErrors()来打印数据模型错误信息
  13. }

根据条件删除集合 deleteAll($condition='',$params=array());

  1. $condition = 'username=:name and password=:pass';
  2. $params = array(':name'=>'www.aipanshi.com',':pass'=>'aipanshi.com');
  3. //删除postid为这些的数据
  4. $boolean = Post::model()->deleteAll('postid in("1,2,3")');
  5. if($boolean > ){
  6. echo "删除成功";
  7. }else{
  8. echo "删除失败";
  9. }
  10. ```

根据主键删除一个集合 deleteByPk($pk,$condition='',$params=array())

  1. $boolean = Post::model()->deleteByPk();
  2. $boolean = Post::model()->deleteByPk(array(,),'username=:name',array(':name'=>'aipanshi.com'));
  3. if($boolean > ){
  4. echo "删除成功";
  5. }else{
  6. echo "删除失败";
  7. }

根据条件 updateAll($attributes,$condition='',$params=array())

  1. $attributes = array('username'=>'www.aipanshi.com','postsort'=>'');
  2. $condition = 'status=:s';
  3. $params = array(':s'=>);
  4. $boolean = Post::model()->updateAll($attributes,$condition,$params);
  5. if($boolean > ){
  6. echo "修改成功";
  7. }else{
  8. echo "修改失败";
  9. }

根据主键 updateByPk($pk,$attributes,$condition='',$params=array())

  1. /**
  2. * $pk主键 也可以是一个数组集合
  3. * $attributes是要修改的字段的集合
  4. * $condition条件
  5. * $params传入的值
  6. */
  7. $attributes = array('username'=>'www.aipanshi.com','password'=>'www.aipanshi.com');
  8. $count =Post::model()->updateByPk(,$attributes);
  9. $attributes2 = array('username'=>'www.aipanshi.com1','password'=>'www.aipanshi.com1');
  10. $condition2 = 'username=:name';
  11. $params2 = array(':name'=>'www.aipanshi.com');
  12. $boolean =Post::model()->updateByPk(array(,),$attributes2,$condition2,$params2);
  13. if($boolean > ){
  14. echo "修改成功";
  15. }else{
  16. echo "修改失败";
  17. }

自增和自减 updateCounters($counters,$condition='',$params=array());

  1. //数据库中的post表根据条件username='www.aipanshi.com',查询出的所有结果status字段都自加1
  2. $counters = array('status'=>);//-1自减
  3. $condition = 'username=:name';
  4. $params = array(':name'=>'www.aipanshi.com');
  5. $boolean=Post::model()->updateCounters($counters,$condition,$params);
  6. if($boolean > ){
  7. echo "修改成功";
  8. }else{
  9. echo "修改失败";
  10. }

查询指定字段

  1. $res = KnowledgeAuthList::model()->find([
  2. 'select' => ['id'],
  3. 'condition' => 'auth_name=:auth_name',
  4. 'params' => [':auth_name'=>'基础']
  5. ]);

根据条件查询一个集合 findAll($condition='',$params=array())

  1. $res=Post::model()->findAll("username=:name",array(":name"=>$username));
  2. $res=Post::model()->findAll("username=:name and status=:s",array(":name"=>'jack',':s'=>));
  3. $info = Post::model()->findAll("status = '1' ORDER BY postid DESC limit 10 ");
  4. ```

根据主键查询一个集合,可以使用多个主键 findAllByPk($pk,$condition='',$params=array())

  1. $condition = "username like :name and status=:s";
  2. $res=Post::model()->findAllByPk($ids,$condition,array(':name'=>$name,':s'=>));
  3. $res=Post::model()->findAllByPk(array(,));

根据数组条件查询一个集合 findAllByAttributes($attributes,$condition='',$params=array())

  1. $res=Post::model()->findAllByAttributes($attributes,$condition,$params);
  2. $res=Post::model()->findAllByAttributes(array('username'=>'www.aipanshi.com'));

根据SQL语句查询一个数组 findAllBySql($sql,$params=array())

  1. $res=Post::model()->findAllBySql($sql,$params);
  2. $sql = "select * from tbl_post where username like :name";
  3. $res=Post::model()->findAllBySql($sql,array(':name'=>'%Jack%'));

根据主键查询出一个对象 findByPk($pk,$condition='',$params=array())

  1. $res=Post::model()->findByPk($postID,$condition,$params);
  2. $res=Post::model()->findByPk();

根据条件查询,他只返回第一行数据find($condition='',$params=array())

  1. $res=Post::model()->find('username=:name',array(':name'=>'www.aipanshi.com'));

根据数组条件查询,查询的也是第一条数据findByAttributes($attributes,$condition='',$params=array())

  1. $res=Post::model()->findByAttributes(array('username'=>'www.aipanshi.com'));

根据SQL语句查询,查询的也是第一条数据 findBySql($sql,$params=array())

  1. $sql = "select * from objectResult where username=:name";
  2. $res=Post::model()->findBySql($sql,array(':name'=>'www.aipanshi.com'));

通过CDbCriteria类find查询出一个对象

  1. $c=new CDbCriteria;
  2. $c->select='username'; // 限制显示哪些字段
  3. $c->condition='username=:username'; //一个查询条件用aCondition.多条件用addCondition
  4. $c->params=array(":username=>'www.aipanshi.com'");
  5. $c->order = "postsort DESC";
  6. $c->limit = "";
  7. $post=Post::model()->find($c);

多条件查询的语句

  1. $c = new CDbCriteria;
  2. $c->addCondition("postid=1"); //等同于 where postid = 1
  3. $c->addInCondition('postid', array(,,,,)); //等同于 where postid IN (1,2,3,4,5,);
  4. $c->addNotInCondition('postid', array(,,,,));//等同于 NOT IN (1,2,3,4,5,)
  5. $c->addCondition('postid=1','OR');//等同于 OR而非AND
  6. $c->addSearchCondition('username', 'www.aipanshi.com');//等同于 where name like '%www.aipanshi.com%'
  7. $c->addBetweenCondition('postid', , );// 等同于 between 1 and 4
  8. $c->compare('postid', ); //根据你的参数自动处理成addCondition或者addInCondition.
  9. $c->compare('postid', array(,,)); //数组就会调用addInCondition
  10. $c->select = 'postid,parentid,name'; //限制显示哪些字段
  11. $c->join = 'xxx'; //连接表
  12. $c->with = 'xxx'; //调用relations
  13. $c->limit = ; //取1条数据,如果小于0,则不作处理
  14. $c->offset = ; //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10
  15. $c->order = 'xxx DESC,XXX ASC' ;//排序条件
  16. $c->group = 'group 条件';
  17. $c->having = 'having 条件 ';
  18. $c->distinct = FALSE; //是否唯一查询

根据一个条件查询一个集合有多少条记录,返回一个int型数字count($condition='',$params=array())

  1. $intCount=Post::model()->count("username=:name",array(":name"=>'aipanshi.com'));

根据SQL语句查询一个集合有多少条记录,返回int型 countBySql($sql,$params=array())

  1. $sql = "select * from objectResult where username=:name";
  2. $intCount=Post::model()->countBySql($sql,array(':name'=>'aipanshi.com'));

根据条件查询有无数据返回一个boolean exists($condition='',$params=array())

  1. $boolExist=Post::model()->exists("name=:name",array(":name"=>'aipanshi.com'));

查询出复合条件的用户数组,指定了index以后,结果数组$users已经是用id做为主键的了

  1. $posts = Post::model()->findAll(array('condition'=>'postsort > 18', 'index'=> 'id'));

摘自:http://www.aipanshi.com/post/type.html?name=yii

YII1 增、删、改、查数据库操作的更多相关文章

  1. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  2. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  3. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  4. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  5. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  6. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  7. python基础中的四大天王-增-删-改-查

    列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...

  8. 【转】Android 增,删,改,查 通讯录中的联系人

    一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...

  9. Android 增,删,改,查 通讯录中的联系人

    一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission. ...

  10. 简单的php数据库操作类代码(增,删,改,查)

    这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...

随机推荐

  1. fetch get方法的时候报错

    fetch 报错 Failed to execute 'fetch' on 'Window': Request with GET/HEAD method cannot have body. 翻译过来就 ...

  2. socket详解(二)----实例和多线程,线程池使用

    一般而言,Java 语言中的套接字有以下两种形式: TCP 套接字(由 Socket 类实现,) UDP 套接字(由 DatagramSocket 类实现) TCP 和 UDP 扮演相同角色,但做法不 ...

  3. js substr和substring

    substr(start[,end]) 字符串截取 start从那里裁,end裁切为数 substring(start[,end = str.length]) // start和end会先处理数值较大 ...

  4. socket.io 中文文档

    Socket.io是一个WebSocket库,包括了客户端的js和服务器端的nodejs,它的目标是构建可以在不同浏览器和移动设备上使用的实时应用.它会自动根据浏览器从WebSocket.AJAX长轮 ...

  5. Java 中的 IO 与 socket 编程 [ 复习 ]

    一.Unix IO 与 IPC Unix IO:Open-Read or Write-Close IPC:open socket - receive and send to socket - clos ...

  6. 面向对象编程之Java多态

    我相信从学习计算机面向对象编程起就很多人背下了继承.封装.多态三个特性,可是多态并不是那么好理解的.通常做几道题,背下几次多态的动态绑定规律,可是依旧在一段时间后忘记了多态的存在,为什么要多态,这个程 ...

  7. linux中的pwd

    https://www.cnblogs.com/crazylqy/p/5818745.html

  8. lower_bound && upper_bound

     用lower_bound进行二分查找 ●在从小到大排好序的基本类型数组上进行二分查找. 这是二分查找的一种版本,试图在已排序的[first,last)中寻找元素value.如果[first,last ...

  9. 搭建Harbor企业级docker仓库

    搭建Harbor企业级docker仓库 一.Harbor简介 1.Harbor介绍 Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器,通过添加一些企业必需的功能特性,例如 ...

  10. Win7升Windows10有获取通知,但是就不推送的解决方法

    1. 删除“C:\Windows\SoftwareDistribution\Download”下所有文件2. 以管理员身份运行命令提示符,输入“wuauclt.exe /updatenow”并回车(注 ...