基本要素: 微擎系统数据库操作使用PDO兼容方式,参数绑定进行查询操作

(1) 数据表加上表前缀

$sql  = "select * from ".tablename('users');

等价  select * from ims_users

(2)范围条件操作

① pdo_get()查询

使用: pdo_get($tablename,$condition,$fields,$limit)

$user = pdo_get('users', array('uid' => 1), array('username', 'uid'));

等价 select  username ,uid  from ims_users where uid =1 limit 1

② pdo_getcolumn()查询  指定查询表中获取一条记录

使用: pdo_getcolumn($tablename,$condition=array(),$fields,$limit)

$user =pdo_getcolumn('users', array('uid' => 1),'username',1));

等价 select  username    from ims_users where uid =1 limit 1

③ pdo_getall()查询  指定查询表中全部记录

使用:pdo_getall($tablename,$condition=array(),$fields=array(),$keyfields='',$orderby =array(), $limit=array())

$user = pdo_getall('users', array('status' => 1), array() , '' , array('uid','groupid') , array(1,10));

//生成的SQL等同于:SELECT  *  FROM ims_users WHERE status ='1'  ORDER BY  uid,groupid  LIMIT 1, 10

②pdo_getslice()查询  指定查询表中获取一条记录

使用:pdo_getslice($tablename, $condition = array(), $limit = array(), &$total = null, $fields = array(), $keyfield = '', $orderby = array())

$user = pdo_getslice('users', array('status' => 2), array(1,10) , $total , array() , '' , array('uid','groupid'));

//生成的SQL等同于$user = SELECT * FROM ims_users WHERE status ='2' ORDER BY uid,groupid LIMIT 1,10

③pdo_fetch()查询一条记录,参数绑定传值,防止SQL注入

pdo_fetch($sql,$params=arrray())

$user = pdo_fetch(" SELECT username, uid FROM " .tablename('users')." WHERE uid =:uid LIMIT 1",array(":uid"=>1));

等价: $sql = select username,uid from ims_users where uid = 1 limit   1

$user = pdo_fetch("SELECT * FROM ".tablename('users')." WHERE username LIKE :username ",array(":username"=>"%mi%"))

等价:$sql = select * from ims_user where user_name like "%mi%";

④pdo_fetchcolumn()  返回值,字符串

pdo_fetchcolumn($sql,$params=array(),$column=int)

$user_total = pdo_fetchcolumn("SELECT count(*)  FROM ".tablename('users') );

⑤pdo_fetchall()

pdo_fetchall($sql,$params=array(),$keyfield="");

$user =  pdo_fetchall("SELECT username,uid FROM ".tablename('users'),array(),'uid');

(3)增,删, 改

新增一条数据

pdo_insert($tablename,$data=array(),$replace =false)

$user_data = array(

'username'=>'mizhou',

'status'=>'1')

$result = pdo_insert('users',$user_data)

更新一条数据

pdo_update($tablename,$data = array(),$condition,$glue='ADD')

$user_data = array(

'username'=>'mi')

$result = pdo_update('users',$user_data,array('id'=>2));

删除指定条件的数据

pdo_delete($tablename,$condition=array(),$glue='ADD')

$result = pdo_delete('users',arrau('username'=>'mi')

自定义SQL执行语句

pdo_query($sql,$params = array())

))

与pdo_query类似的是pdo_run

pdo_run 可一次执行多条语句,sql语句之间以;分割

例如

$sql = <<< EOF

$sql1 ;$sql2; $sql3

EOF;

pdo_run($sql);

pdo_debug()调试模式

INNODB事物表的处理逻辑

使用 pdo_begin();    pdo_commit();   pdo_rollback()

 

微擎开发------day02的更多相关文章

  1. 微擎开发------day04

    (1) cache_write($key,$data)  按照指定键名缓存数据 cache_write('test', $data) (2) cache_load($key)  读取指定键名的缓存数据 ...

  2. 微擎开发------day03

    微擎系统的路由 首先附上一张完整的项目目录图,可下载图片后查看详情 详细的路由介绍 (1)后台系统路由 例如:http://local.drp.com/web/index.php?c=home& ...

  3. 微擎开发------day01

    微擎的数据常量 $_GPC   -- 全局请求变量 类型: array 说明: 合并请求参数, 包括 $_GET, $_POST, $_COOKIE的内容. 相同键名覆盖规则为 $_COOKIE 覆盖 ...

  4. 微擎app端上传图片后删除不了图片

    相信在微擎开发的哥们都知道, 微擎在手册方面还是有点坑的,根本不让人活啊.没办法, 开发时, 只能自己看着源码来搞>>>> 好, 不多说了. 现在来看一个坑  ..直接上代码\ ...

  5. 玩转微信2次开发1_交互通信api.php(微擎版)

    在2次开发中,涉及到比较多的也比较繁琐的就是服务器和微信服务器的交互 用户在公众号里操作回复关键词都会让微信服务器和开发者的服务器进行交互 用户一旦关注了某某公众号--微信后台会去查询该公众号是否连接 ...

  6. 微擎模块的安装文件manifest.xml

    微擎在安装或卸载模块时会根据manifest.xml生成(或删除)数据库中相应记录,并执行manifest.xml里指定的脚本. manifest.xml文件内容详细介绍如下: manifest - ...

  7. 微擎开启redis memcache文档2

    微擎开启redis memcache 2018年01月20日 14:39:54 luogan129 阅读数:2161更多 个人分类: 微信开发   版权声明:本文为博主原创文章,未经博主允许不得转载. ...

  8. 微擎开启redis memcache

    微擎开启redis memcache 2018年01月20日 14:39:54 luogan129 阅读数:2161更多 个人分类: 微信开发   版权声明:本文为博主原创文章,未经博主允许不得转载. ...

  9. [转]Linux 微擎系统搭建

    本文转自:https://www.cnblogs.com/voidking/p/5296552.html 前言 时隔一年半,再次接触微信公众平台开发.相比于掌上大学.圈里.微站ABC.图灵机器人.小i ...

随机推荐

  1. tcpdump抓包常用参数和用法

    tcpdump 与wireshark Wireshark(以前是ethereal)是Windows下非常简单易用的抓包工具.但在Linux下很难找到一个好用的图形化抓包工具.还好有Tcpdump.我们 ...

  2. zookeeper启动时报Cannot open channel to X at election address Error contacting service. It is probably not running.

    配置storm集群的时候出现如下异常: 2016-06-26 14:10:17,484 [myid:1] - WARN [SyncThread:1:FileTxnLog@334] - fsync-in ...

  3. 3.1 MathType上标位置调整的两种方法

    具体操作步骤如下: 1.打开MathType窗口后在工作区域中编辑好公式. 2.调整上标位置有两种方法: (1)选中要调整的上标,按下“Ctrl+↑,Ctrl+↓,Ctrl+←,Ctrl+→”进行调整 ...

  4. MySQL通过分组计算百分比

    公司在做柯米克的分析报告,需要我这边把汽车之家柯米克论坛的评论数据和评论用户所在地的数据获取,通过爬虫的方式很快的解决了数据的问题,但是需要我提取下各省评论人数的比例,所以在数据库里面直接计算了相关的 ...

  5. 第二章 C#语法基础(2.1 C#语言的数据类型一)

    C#的数据类型 [案例]本案例实现3位评委给一位选手评分,通过键盘输入各位评委的打分,通过屏幕输出该选手的平均分. [案例目的] (1)掌握变量的定义方式; (2)掌握常用的数据类型; (3)掌握数据 ...

  6. List进行排序

    使用Java中提供的对集合进行操作的工具类Collections,其中的sort方法,重写比较方法 /** * 根据序号对列席人进行排序 * @param lxrUser * @return */ p ...

  7. jmeter配置脚本录制进行抓包并快速分析、定位接口问题

    对于测试人员.开发人员来说,善用抓包工具确实是快速分析和定位问题的一大必备神技,现将配置过程记录如下: 1.打开jmeter后,首先添加一个线程组: 2.线程组可以重新命名按项目名称分类 3.然后在工 ...

  8. nginx配置分发Tomcat服务,负载均衡

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 项目中瓦片资源越来越多,如果提高瓦片的访问效率是一个需要解决的 ...

  9. 20165312 2017-2018-2 《JAVA程序设计》第2周学习总结

    20165312 2017-2018-2 <JAVA程序设计>第2周学习总结 一.对上一周学习的查漏补缺 1.上周在虚拟机中进行编译程序时出现错误,在上一周的博客中我有提到,当时还未找到解 ...

  10. Python-实列

    """题目:有四个数字:1.2.3.4,能组成多少个互不相同且无重复数字的三位数?各是多少? 程序分析:可填在百位.十位.个位的数字都是1.2.3.4.组成所有的排列后再 ...