php mysql 类库_PHP数据库操作之基于Mysqli的数据库操作类库
此类库简单、易用,便于你自己修改和对功能的改善,能解决大部分 PHP 项目中执行的 SQL 操作。
初步工作
首先,请大家下载这个类库 M.class.php 再下载一个 Mysqli 连接数据库的类库 MysqliDb.class.php(打包下载地址)
新建一个 includes 的文件夹,将下载下来的两个 class 文件,放进去。
然后,请你在项目下创建一个 test.php 文件。注:UTF-8 文件格式
请先根据你机器的情况,填充以下代码,用于连接数据库:
header('Content-Type:text/html;Charset=utf-8');
define('ROOT_PATH', dirname(__FILE__));
define('DB_HOST', 'localhost'); //数据库服务器地址
define('DB_USER', 'root'); //数据库用户名
define('DB_PWD', '×××');//数据库密码
define('DB_NAME', '×××'); //数据库名称
define('DB_PORT', '3306'); //数据库端口
function __autoload($className) {
require_once ROOT_PATH . '/includes/'. ucfirst($className) .'.class.php'; //自动加载 class 文件
}
好了,上面的这些操作都是初步工作,下面正式进入类库的讲解。
类库讲解
首先,我们得实例化 M.class.php,实例化很简单:
$m = new M(); //这步操作代表 M.class.php 中的所有功能都封装在了变量 $m 中
注:
1、M类库中的方法参数说明,请到 M.class.php 文件中看详细的注释,这里不再进行叙述。建议在学习的时候,对照着看下文件中的参数即注释。
2、讲解代码中用到的数据库结构为:
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
并添加一条测试数据。
3、M类库中,大部分方法都分两中类型,即:SQL方法;拼接方法,具体在实例中可以看出
4、以下称述中的 M 为 M.class.php 文件
方法1、Insert() 添加数据
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() 修改数据
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() 删除数据
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
Del 方法的全部使用案例如下:
$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() 返回单条数据,返回值为一维数组
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() 返回单个数据
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 拼接错误,类库会报出友善的错误提示。
有问题请留言,欢迎大家的批评和建议,加油!学习好运。
php mysql 类库_PHP数据库操作之基于Mysqli的数据库操作类库相关推荐
- php操作mysql类库_PHP数据库操作之基于Mysqli的数据库操作类库_PHP
此类库简单.易用,便于你自己修改和对功能的改善,能解决大部分 PHP 项目中执行的 SQL 操作. 初步工作 首先,请大家下载这个类库 M.class.php 再下载一个 Mysqli 连接数据库的类 ...
- 数据库管理系统(基于前端+后端+数据库)
库存管理系统 包括模块: (1)基本信息管理. (2)商品入库管理. (3)商品出库管理. (4)商品查询管理. (5)查看商品目录. 实训步骤: 开发环境:html , css , js , p ...
- php mysql书城_php在线书城 thinkphp源码(含数据库脚本)
[实例简介] [实例截图] [核心代码] // 本类由系统自动生成,仅供测试用途 class IndexAction extends PublicAction { public function in ...
- php7数据库备份还原,基于thinkphp的数据库在线备份还原
搜索了不少资料,东拼西凑总算完成了.下面贴出来代码,原理就不讲解了,代码挺简单的,重要部分我都做了注释.<?php use Think\Db; /** * 数据库备份还原类 * @author ...
- Spring基于AspectJ实现AOP操作
基于AspectJ实现AOP操作 准备工作 在项目工程里面引入 AOP 相关依赖. 如果是maven项目,使用pom.xml代替引入jar包的过程(注意) 学会使用切入点表达式 AOP 操作(Aspe ...
- 【android免root脚本制作】基于控件的操作——auto.js进阶
在[android免root脚本制作]自动坐标操作手机--京东金融程序金果摇钱树自动收金果 之后,想要做进一步优化,因为基于坐标点击如何屏幕被移动之类就会点击错位,不同手机还需去适配坐标,甚是麻烦,所 ...
- python多线程读取数据库数据_Python基于多线程操作数据库相关知识点详解
Python基于多线程操作数据库相关问题分析 本文实例分析了Python多线程操作数据库相关问题.分享给大家供大家参考,具体如下: python多线程并发操作数据库,会存在链接数据库超时.数据库连接丢 ...
- ef mysql 读写分离_基于 EntityFramework 的数据库主从读写分离服务插件
基于 EntityFramework 的数据库主从读写分离服务插件 1. 版本信息和源码 1.1版本信息 v1.01 beta(2015-04-07),基于 EF 6.1 开发,支持 EF 6.1 之 ...
- 【MySQL数据库系列】一、认识数据库、建库建表操作
文章目录 一.初识数据库 二.MySQL基本数据类型 三.MySQL基本逻辑运算符 四."数据库"的基本操作 五."表"的基本操作 一.初识数据库 数据库:能更 ...
最新文章
- 查询增速200倍!看金融业数据库架构如何在蜕变中逆袭
- 离职交接文档_如何写好离职工作交接文档?
- 怎样用c语言写一个系统,用C语言写关于操作系统的一个问题。
- ### Error building SqlSession.### The error may exist in entity/UserMapper.xml
- frameset用法
- 跟我学: 使用 fireasy 搭建 asp.net core 项目系列之一 —— 开篇
- PCB genesis自制孔点 Font字体实现方法
- 说说 JavaScript 计时器的工作原理
- bootstrap中日历组件只显示年月
- 海康工业相机的一些坑(USB接口的相机连上halcon17后,客户端无法打开相机,错误是无驱动,但是驱动是好好的,如何解决)
- lidar与相机联合标定开源软件介绍
- Android域名解析优先ipv6,IPv6 域名解析原理及编程实现
- IP地址聚合-路由汇聚_共同前缀(1.相似部分2.最后一组二进制比较,取相同,算位数3.转十进制,加位数)
- 怎么才能打开dwg图纸?
- 构造图片木马,绕过文件内容检测上传木马
- 如何评价 APICloud ?
- oracle trace进程,ORACLE SQL_TRACE的使用
- EVPN中ESI与EVI的区别
- 学计算机要Ghz,ghz是什么意思,电脑ghz是什么意思?
- 通达信交易系统接口是不是免费的?