M类库中的方法参数说明,请到 M.class.php 文件中看详细的注释,这里不再进行叙述。建议在学习的时候,对照着看下文件中的参数即注释。

讲解代码中用到的数据库结构为:

CREATE TABLE `user` (

`id` int(8) unsigned NOT NULL auto_increment,

`name` varchar(50) default NULL,

`email` varchar(100) default NULL,

`age` smallint(3) default NULL,

`class_id` int(8) default NULL,

`commit_time` int(10) default NULL,

PRIMARY KEY (`id`),

KEY `name` (`name`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8

CREATE TABLE `class` (

`class_id` int(8) NOT NULL auto_increment,

`class_name` varchar(100) default NULL,

PRIMARY KEY (`class_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8

M类库中,大部分方法都分两中类型,即:SQL方法;拼接方法,具体在实例中可以看出

以下称述中的 M 为 M.class.php 文件

方法1、Insert() 添加数据

$m->Insert("user", null, array('焦焦', 'liruxing1715@sina.com', '23', time())); // 拼接方法:往`user`表中添加一条数据,返回值为数据库影响的行数

$m->Insert("user", null, array('焦焦', 'liruxing1715@sina.com', '23', time()), true); // 功能同上,返回 last_insert_id(插入的增长id)

$m->Insert("INSERT INTO `user` (`name`, `email`, `age`, `commit_time`) VALUES ('张小花', 'zhangxiaohua@sina.com.cn', '22', '".time()."')"); //SQL方法,返回值为数据库影响的行数

$m->Insert("INSERT INTO `user` (`name`, `email`, `age`, `commit_time`) VALUES ('张小花', 'zhangxiaohua@sina.com.cn', '22', '".time()."')", true); // 同上,返回 last_insert_id

注:Insert 方法中的第二个参数若为null,可自动获得插入表除 auto_increment 字段之外的所有字段,详情请看M源文件;若要返回值为最后插入的 ID,那么请设置 Insert 方法的最后一个参数为 true(默认是false);

方法2、Update() 修改数据

$m->Update("user", array('name'=>'李茹茹', 'age'=>24), "id=1"); // 拼接方法,修改id为1的数据的名称为“李茹茹”;年龄为“24”,其方法的返回值为受影响的行数

$m->Update("UPDATE `user` SET `name`='李茹茹', `age`=24 WHERE id = 1"); //SQL 用法,功能同上

方法3、Del() 删除数据

$m->Del('user', 'id=3'); //拼接方法:删除`user`表中 id 为3的数据,返回受影响的行数

$m->Del("DELETE FROM `user` WHERE id=4"); //SQL方法:删除`user`表中 id 为4的数据,返回受影响的行数

$m->Del("DELETE FROM `user` WHERE id in (10, 11, 12)"); //SQL方法:删除多条数据,删除`user`表中 id 为 10、11、12 的数据,返回受影响的行数

方法4、Total() 获取记录数,返回值都为int

$m->Total('user'); //拼接方法:返回 `user`表中的记录数,无条件

$m->Total('user', 'id>1'); //拼接方法:返回 `user`表中 id 大于1的记录数,有条件

$m->Total("SELECT COUNT(*) AS total FROM `user`"); //SQL方法,注:使用SQL方法,语句中必须使用 "AS total",否则会报错

方法5、IsExists() 检查数据是否存在,返回值为boolean

$m->IsExists('user', "`name`='焦焦'"); //拼接方法:返回`user`表中是否存在`name`为“焦焦”的数据,返回true,若不存在,返回false

方法6、InsertId() 获取表下一个添加的自动增长id,注意,这里不进行添加操作,只是获取下一个增长id

echo $m->InsertId('user'); //获取`user` 表下一个添加的自动增长id

方法7、GetRow() 返回单条数据,返回值为一维数组

$data = $m->GetRow("SELECT `name`,email FROM `user` WHERE id=1"); //SQL方法,返回一维数组,例如:Array ( [name] => 焦焦 [email] => liruxing1715@sina.com )

$data = $m->GetRow("SELECT u.`name`, u.email, c.class_name FROM `user` u, `class` c WHERE u.class_id=c.class_id AND u.id=1"); //SQL方法,多表查询

$data = $m->GetRow('user', '`name`,email', "id=1"); //拼接方法

$data = $m->GetRow('user as u,`class` c', 'u.`name`,u.email,c.class_name', "u.id=1 AND u.class_id=c.class_id"); //拼接方法,多表查询

$data = $m->GetRow("SELECT `name`,email FROM `user`"); //如果没有指定条件应该是显示全部信息,但是在此方法中将默认显示第一条(不推荐这么使用!!!)

$data 是查询出来的一维数组。

方法8、GetOne() 返回单个数据

$name = $m->GetOne("SELECT `name` FROM `user` WHERE id=1"); //SQL方法,返回一个字符串,例如:焦焦

$name = $m->GetOne("user", "name", "id=1"); //拼接方法,返回一个字符串,例如:焦焦

方法9、FetchAll() 返回所有记录

$data = $m->FetchAll("user"); //返回`user`表中的所有记录,以二维数组的形式

$data = $m->FetchAll("SELECT * FROM `user`"); //SQL 方法,功能和返回值同上

$data = $m->FetchAll("user", "name,email", "id>1", 'id DESC', '2'); //返回两条id>1的数据,只显示name,email,并且以id 为倒序排序。注:请注意该方法的最后一个参数也可以为'0,2',目的是为分页准备的,如果第一页为'0,2'的话,那么第二页就是'2,2'

//该方法也支持联表查询和多表查询,下面以联表查询为例

$data = $m->FetchAll("`user` as u LEFT JOIN `class` as c ON u.class_id=c.class_id", "u.`name`,u.email, c.class_name", "u.id=1"); //注意:该拼接方法中,ON 添加的位置

注:对于该 FetchAll 方法,后续我会写一篇使用该方法进行完美分页的文章!!请关注。

方法10、MultiQuery() 执行多条SQL语句

$sql = "INSERT INTO user (`name`,email, age, class_id, commit_time) VALUES ('贾花花', 'jiahuahua@sina.com.cn', '22', '1', '".time()."')"; //添加一个名叫“贾花花”的学生信息

$sql .= ";DELETE FROM `user` WHERE `name`='焦焦'"; //删除一条名叫“焦焦”的学生信息

//解释:$sql 是多条 SQL 以英文;(分号)拼接起来的

$data = $m->MultiQuery($sql); //返回为true,代表执行成功;为false,代表执行失败

类库讲解完毕

到此该类库的全部功能就讲解完毕,希望你能多看看M文件,了解其内部运行的机制。M 文件不会存在执行缓慢情况,请大家放心使用。

如果在使用过程中出现 SQL 拼接错误,类库会报出友善的错误提示。

mysqli.class.php,php_mysqli_class相关推荐

  1. php错误提示如何查询,php-如何显示我的MySQLi查询错误?

    这个问题已经在这里有了答案: mysqli_fetch_assoc()期望参数/调用成员函数bind_param()错误. 如何获取并修复实际的mysql错误? 1个答案 mysqli还是死了,它必须 ...

  2. php mysql函数未定义,PHP MySQLi未定义的方法错误

    我使用MySQLi创建了一些基本的OO脚本,并且当我使用stmt_init(),prepare()或query()...时发生未定义的方法错误...并且connect_errno()出现错误.我知道在 ...

  3. wdcp php5.3 pdo_mysql,WDCP常用组件(memcache、mysqli、PDO_MYSQL、mysql innodb、libmcrypt、php zip)的安装方法...

    一般来说WDCP安装之后就可以正常使用了,不过对于一些朋友来说还无法满足,现在收集了有关WDCP常用组件,比如memcache.mysqli.PDO_MYSQL.mysql innodb.libmcr ...

  4. php mysql预处理_php mysqli扩展之预处理

    在前一篇 mysqli基础知识中谈到mysqli的安装及基础操作(主要是单条sql语句的查询操作),今天介绍的是mysqli中很重要的一个部分:预处理. 在mysqli操作中常常涉及到它的三个主要类: ...

  5. php 开启mysql_php如何开启mysqli扩展

    php开启mysqli扩展的方法:首先打开php.ini配置文件:然后找到[extension=php_mysqli.dll],并取消注释:最后找到[extension_dir],设置ext路径即可. ...

  6. php mysqli参数,PHP5 mysqli 绑定参数

    所谓绑定参数就是把PHP脚本中的自定义变量绑定到SQL语句中的参数(参数使用 "?"代替)上,绑定参数使用bind_param()方法,该方法的语法格式如下: bool bind_ ...

  7. mac-PHP mysqli连接报错 No such file or directory解决方案

    今天在玩WordPress.安装时连不上数据库但是数据库账号密码全是可以的,使用Navicat也能连上.最终查询到错误No such file or directory 解决方案 原因是mysqli找 ...

  8. Mysqli的批量CRUD数据

    学会了使用了mysqli扩展库之后,总体感觉比面向过程的方法更加合理化,面向对象是大势所趋,所以绝不能仅仅只用那一套老的mysql库 了,也不利于php对mysql的操作,因为我们在实际的开发中,很多 ...

  9. php mysqli扩展之预处理

    在前一篇 mysqli基础知识中谈到mysqli的安装及基础操作(主要是单条sql语句的查询操作),今天介绍的是mysqli中很重要的一个部分:预处理. 在mysqli操作中常常涉及到它的三个主要类: ...

最新文章

  1. 1126 Eulerian Path
  2. golang float string int 相互转换 保留小数位
  3. 001_FastDFS介绍
  4. python if __name__ == '__main__'
  5. 判断回文链表(剑指offer.027)
  6. Docker 核心概念、安装、端口映射及常用操作命令,详细到令人发指。
  7. 取得成本中心组、成本要素组层级的几个BAPI
  8. 单片机产生可调方波(c语言),单片机产生占空比可调方波(PWM)
  9. html打包成app的缓存问题,webpack 独立打包与缓存处理
  10. Scala 写第一个程序HelloWorld
  11. [Ubuntu] Simple way to pass passwords on a shell script
  12. matalotlib(2)
  13. 现代软件工程系列 学生读后感 梦断代码 DTSlob (2)
  14. azure不支持哪些语句 sql_排查 Azure SQL 数据库的常见连接问题 - Azure SQL Database | Microsoft Docs...
  15. SVN回滚至某个版本
  16. 一步一步使用 DialogFragment 封装链式调用 Dialog
  17. html制作翻牌游戏,基于javascript实现句子翻牌网页版小游戏
  18. 安川机器人梯形图指令(一)
  19. 数字化转型之道:谈谈企业如何落地数据治理
  20. 【数据分析】2022 年将占据主导地位的 3 种数据和分析趋势

热门文章

  1. switch语句的作用
  2. redis连接应用服务器,使用redis-cli连接Redis服务器
  3. js 日期比较 相差天数
  4. vue版pdf.js 在线预览pdf文件流
  5. 【In-Context Learning】Meta-learning via Language Model In-context Tuning
  6. 《生命》第一集:Chanllenge of Life (生命的挑战)
  7. 华为nova8什么时候上市
  8. 写一个面试应聘者信息填入程序
  9. 网卡清空缓存命令_WIN10如何清除网络缓存图文教程
  10. Word 里公式编辑有黑色圆圈显示不出