1. 数据库代码:

    /*

    Navicat MySQL Data Transfer

    Source Server         : lonxom

    Source Server Version : 50524

    Source Host           : localhost:3306

    Source Database       : test

    Target Server Type    : MYSQL

    Target Server Version : 50524

    File Encoding         : 65001

    Date: 2013-10-12 00:03:03

    */

    SET FOREIGN_KEY_CHECKS=0;

    -- ----------------------------

    -- Table structure for `city`

    -- ----------------------------

    DROP TABLE IF EXISTS `city`;

    CREATE TABLE `city` (

    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,

    `name` varchar(32) COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT '城市名',

    PRIMARY KEY (`id`)

    ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci COMMENT='城市表';

    -- ----------------------------

    -- Records of city

    -- ----------------------------

    INSERT INTO `city` VALUES ('1', '北京');

    INSERT INTO `city` VALUES ('2', '上海');

    INSERT INTO `city` VALUES ('3', '广州');

    INSERT INTO `city` VALUES ('4', '武汉');

    INSERT INTO `city` VALUES ('5', '天津');

    -- ----------------------------

    -- Table structure for `user`

    -- ----------------------------

    DROP TABLE IF EXISTS `user`;

    CREATE TABLE `user` (

    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,

    `username` varchar(32) CHARACTER SET utf8 NOT NULL COMMENT '用户名',

    `city_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '城市',

    `create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',

    `update_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',

    PRIMARY KEY (`id`)

    ) ENGINE=InnoDB AUTO_INCREMENT=23 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci COMMENT='用户表';

    -- ----------------------------

    -- Records of user

    -- ----------------------------

    INSERT INTO `user` VALUES ('2', '菩提', '2', '0', '0');

    INSERT INTO `user` VALUES ('3', '天师', '5', '0', '0');

    INSERT INTO `user` VALUES ('5', '久1', '3', '0', '0');

    INSERT INTO `user` VALUES ('6', '久2', '4', '0', '0');

    INSERT INTO `user` VALUES ('7', '久3', '1', '0', '0');

    INSERT INTO `user` VALUES ('8', '久4', '4', '0', '0');

    INSERT INTO `user` VALUES ('9', '久5', '5', '0', '0');

    INSERT INTO `user` VALUES ('10', '久6', '1', '0', '0');

    INSERT INTO `user` VALUES ('11', '久7', '3', '0', '0');

    INSERT INTO `user` VALUES ('12', '久8', '3', '0', '0');

    INSERT INTO `user` VALUES ('13', '久9', '1', '0', '0');

    INSERT INTO `user` VALUES ('14', '帅帅', '1', '1381395175', '1381395175');

    INSERT INTO `user` VALUES ('15', '小猪猪', '1', '1381396237', '1381463258');

    INSERT INTO `user` VALUES ('16', '阿浩', '2', '1381396559', '1381396559');

    INSERT INTO `user` VALUES ('17', '鹏鹏', '1', '1381398344', '1381398344');

    INSERT INTO `user` VALUES ('18', '方方', '5', '1381398969', '1381398969');

    INSERT INTO `user` VALUES ('19', '官人', '1', '1381456860', '1381456860');

    INSERT INTO `user` VALUES ('20', '谢平', '4', '1381461563', '1381461563');

    INSERT INTO `user` VALUES ('21', '元方', '2', '1381463288', '1381463288');

    INSERT INTO `user` VALUES ('22', '康师傅', '1', '1381500128', '1381500128');

    -- ----------------------------

    -- Table structure for `user_info`

    -- ----------------------------

    DROP TABLE IF EXISTS `user_info`;

    CREATE TABLE `user_info` (

    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,

    `user_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户表id',

    `info` text CHARACTER SET utf8 COMMENT '用户简介',

    PRIMARY KEY (`id`)

    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci COMMENT='用户信息表';

    -- ----------------------------

    -- Records of user_info

    -- ----------------------------

    INSERT INTO `user_info` VALUES ('1', '15', '我是一个好人');

    END

基本查询方法

  1. 1

    //DAO方式的  插入动作

    public function actionCreate()

    {

    $res=Yii::app()->db->createCommand()->insert("user",array(

    'username'=>'水墨淡清',

    ));

    dump($res,FALSE);

    dump(Yii::app()->db->getLastInsertID());//获取最新插入的ID

    }

  2. 2

    //DAO方式的  修改动作

    public function actionUpdate()

    {

    $res=Yii::app()->db->createCommand()->update('user',array(

    'username'=>'我是来玩的'

    ), 'id=:id',array(':id'=>24));

    dump($res);

    }

  3. 3

     //DAO方式的  删除动作

    public function actionDelete($id)

    {

    $id=trim($id);

    $res=Yii::app()->db->createCommand()->delete('user','id=:id',array(':id'=>$id));

    dump($res);

    }

  4. 4

    //单条数据查询 queryRow()

    public function actionRow()

    {

    $row=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where('id=:id',array(':id'=>2))->queryRow();

    dump($row);

    }

  5. 5

    //多条数据查询 queryAll()

    public function actionAll()

    {

    $all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where('id>:id',array(':id'=>1))->queryAll();

    dump($all);

    }

  6. 6

    //统计数据数量 queryScalar()

    public function actionScalar()

    {

    $scalar=Yii::app()->db->createCommand()->select('count(1)')->from('user')->where('id>:id',array(':id'=>1))->queryScalar();

    dump($scalar);

    }

  7. 7

    //查询所有的ID

    public function actionColumn()

    {

    $ids=Yii::app()->db->createCommand()->select('id')->from('user')->where('id>:id',array(':id'=>1))->queryColumn();

    dump($ids);

    }

    END

基本查询条件方法

  1.  

     //查询出ID大于1 并且小于5的所有数据集合 

    //and()方法

    //$all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where('id>:id and id<5',array(':id'=>1))->queryAll();

    //and()数组方法

    //$all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where(array('and','id>1','id<5'))->queryAll();

    //andWhere()方法

    //$all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where('id>:id',array(':id'=>1))->andWhere('id<:eid',array(':eid'=>5))->queryAll();

  2.  

     //使用in查询出id在5和6里面的数据集合

    //$all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where(array('in','id',array(5,6)))->queryAll();

  3.  

     //使用like查询 并且 ID大于6小于10

    //$all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where(array('like','username','%久%'))->andWhere(array('and','id>6','id<10'))->queryAll();

  4.  

    //查询出名字里面带有9的 3条数据 ID倒序 略过3条数据

    //$all=Yii::app()->db->createCommand()->select('id,username,city_id')->from('user')->where(array('like','username','%久%'))->limit(3)->offset(3)->order('id desc')->queryAll();

    dump($all);

  5. 5

     //关联查询 

    public function actionJoin()

    {

    //取出id 大于 2 小于 6的所有用户信息并取出城市名称

    $users=Yii::app()->db->createCommand()->select('u.id,u.username,c.name')

    ->from('user u')

    ->join('city c','c.id=u.city_id')

    ->where('u.id>2')

    ->andWhere('u.id<6')

    ->queryAll();

    dump($users);

    }

yii DAO操作总结的更多相关文章

  1. Dao操作的抽取,BaseDao

    Dao操作通用的步骤: 0. 写SQL语句 1. 获取连接 2. 创建stmt 3. 执行sql a) 更新 b) 查询 4. 关闭/异常 代码: BaseDao /** * 通用的dao,自己写的所 ...

  2. Yii数据库操作增删改查-[增加\查询\更新\删除 AR模式]

    在Yii的开发中常常需要去使用Yii的增删改查方法,这些方法又可以多次变化和组合,带来全方位的实现对数据库的处理,下面对这些方法做一些简单的整理和梳理,有遗漏或是BUG,敬请指出.灰常感谢!!! 一. ...

  3. Java通过代理类实现数据库DAO操作

    下面的所有代码示例都取自李兴华的<Java Web开发实战经典>的随书源码,因为觉得设计得很好,所以将代码摘录下来作成笔记. 首先,我们在一个java文件中定义要存储的结构类型: impo ...

  4. YII数据库操作(CURD操作)

    数据库操作 获得模型对象 $model = 模型名::model();或$model = new 模型名(); 1.查询多条记录(返回值:二维数组) $result = $model->find ...

  5. Yii框架操作数据库的几种方式与mysql_escape_string

    一.Yii操作数据库的几种选择 1,PDO方式. $sql = "";//原生态sql语句 xx::model()->dbConnection->createComma ...

  6. yii常用操作函数

    <?php defined('YII_DEBUG') or define('YII_DEBUG', true); //当在调试模式下,应用会保留更多日志信息,如果抛出异常,会显示详细的错误调用堆 ...

  7. 中阶 d03.5 (正篇)完整的Dao 操作数据库

    1.目录结构: util---JDBCUtil.java(工具包,整合建立链接和释放资源的方法) dao---UserDao.java(接口,定义方法) impl---UserDaoImpl.java ...

  8. Yii cookie操作

    设置cookie: $cookie = new CHttpCookie('mycookie','this is my cookie'); $cookie->expire = time()+60* ...

  9. Yii的操作提示框

    效果如图 HTML + CSS<style> div.error{ background: #FFE0E0; border: 2px solid #FFA0A0; padding: 10p ...

随机推荐

  1. Android TV开发中所有的遥控器按键监听及注意事项,新增home键监听

    原文:Android TV开发中所有的遥控器按键监听及注意事项,新增home键监听 简单记录下android 盒子开发遥控器的监听 ,希望能帮到新入门的朋友们 不多说,直接贴代码 public cla ...

  2. 算法模型的 Motivations

    neurally-inspired biologically-inspired 1. CNN:biologically-inspired CNN(Convolutional Neural Networ ...

  3. 【树转数组】poj1195

    /* 二维的树状数组: 更新某个元素时: NO.1:c[n1],c[n2],c[n3],....,c[nm]; 当中n1 = i,n(i+1) = ni+lowbit(ni); nm+lowbit(n ...

  4. SecureCRT循环检查设备状态

    1: #$language = "VBScript" 2: #$interface = "1.0" 3: 4: ' This automatically gen ...

  5. Python缺乏调查的陷阱 动态实例属性、引用、逃生

    --看到哪里.想到哪里,记到哪里 非常多时候.非常多人学python的时候,会忽略的东西非常多.大多数都盯着能"出货"即可,可是通常在读别人的代码的时候发现,看不懂...一方面是自 ...

  6. matlab 工具函数 —— axnote(在坐标轴上写文本内容)

    function axnote(string) font_size = get(0, 'DefaultAxesFontSize'); if 1 h1 = text(0.99, 0.05, string ...

  7. 通通玩blend美工(8)——动态绘制路径动画,画出个萌妹子~

    原文:通通玩blend美工(8)--动态绘制路径动画,画出个萌妹子~ 2年前我在玩Flex的时候就一直有一个疑问,就是如何来实现一个蚊香慢慢烧完的Loading动画呢? 刚经历了某甲方高强度一个月的洗 ...

  8. 【C#】wpf添加gif动图支持

    原文:[C#]wpf添加gif动图支持 1.nuget里下载XamlAnimatedGif包,然后安装. 2.添加XamlAnimatedGif包的命名空间:xmlns:gif="https ...

  9. Win8Metro(C#)数字图像处理--2.18图像平移变换

    原文:Win8Metro(C#)数字图像处理--2.18图像平移变换  [函数名称] 图像平移变换函数TranslationProcess(WriteableBitmap src,int x,in ...

  10. QT的进程与线程(cmd /c的写法)

    该文章原创于Qter开源社区(www.qter.org),作者yafeilinux,转载请注明出处! 导语 在前面的几节内容中讲解了Qt网络编程的一些基本内容,这一节来看一下在Qt中进程和线程的基本应 ...