理解抽象类最快的方法就是使用场景,最近在看布尔PHP视频中看到这样的讲解非常容易懂,分享出来。
假设如下场景:
团队准备开发某网站,表建好了,页面设计好了.
A组负责开发底层数据库操作类(DB)(多个DB类,操作Mysql类,操作SQLSERVER,SQLlite......).
B级负责调用DB类.
A组发生了争执,MySQL? Oracle? DB2? sqlite?规范是什么?
B组.... 在争执中漫长等待.
能否让B组不等待?
解决:
A组和B组先定1个数据库类的模板:
模板中对 方法名,参数,返回值,都做严格的规定
此时不管A组选用什么数据库,对于B组来说,没有任何影响;
代码如下:(只需要知道抽象类是一种规范,具体实现由子类来做。)
//定义一个抽象类,相当于模板
abstract class DB{
/*
* 连接数据库,从配置文件读取配置信息
*
*/
abstract public function conn();
/*
* 执行参数中的sql语句
*
*/
abstract public function query($sql);
/*
* 获取多行数据
*
*/
abstract public function getAll();
/*
* 获取单条数据
*
*/
abstract public function getOne();
/*
* 自定义创建Sql语句执行 (数据关联数组,表名字,动作,条件)
*
*/
abstract public function Exce($data,$table,$act='insert',$where='0');
/*
* 返回上一条insert语句产生的主键值
*
*/
abstract public function lastId();
/*
* 返回上一条语句影响的行数
*
*/
abstract public function affectRows();
}
//01.使用抽象类先来创建一个Mysql操作类
class Mysql extends DB{
public function __construct(){
}
public function conn(){
}
public function query($sql){
}
public function getAll(){
}
public function getOne(){
}
public function Exce($data,$table,$act='insert',$where='0'){
}
public function lastId(){
}
public function affectRows(){
}
}
//02.使用抽象类先来创建一个Mssql操作类
class Mssql extends DB{
public function __construct(){
}
public function conn(){
}
public function query($sql){
}
public function getAll(){
}
public function getOne(){
}
public function Exce($data,$table,$act='insert',$where='0'){
}
public function lastId(){
}
public function affectRows(){
}
}
获取浏览器信息原理是基于浏览器的UA信息,早在AsP时代就这样判断,但是腾讯总是喜欢自己折腾,不知道以后会修改成什么! 提取自人人商城官方自带的判断方法:function is_weiXin() { if (empty($_SERV...
php官方已经提供了Iterator(迭代器)接口,通过网上资料的学习,目前看适合超大集合或者数组提取使用。学习一个函数的实现对比内存占用差距.使用迭代器和普通循环实现range()函数。(1).普通循环实现range()函数。function newrange($low, $h...
php arrayaccess 官方的说法是让你能以数组的形式访问对象,对于这种php内置接口一直不太明白有什么用,坚持多看文章,终于理解,特来分享,思路不同,更易于理解。(1).创建一个学生类,并且实现arrayaccess 接口。<?php class studen...
重构框架的时候想要考虑支持下cli模式,于是参考了thinkphp的底层。/** * 获取应用根目录 * @return string */ public static function getRootP...
参数中包含gb2312的字符串,返回结果是false或者null(不同PHP版本具有差异性)代码:<?php $dbms = 'mysql'; $host = '192.168.8.8'; $dbName =&n...
最近在项目中处理一个关于商品数据重复需要删除多余的商品记录,但是删除一条商品必然要把关联的其他表商品的id和其他商品信息更换为正确的,删除一个商品记录,同时要去修改100多张表的关联商品数据,在项目中引用了tp orm 1.2版本,由于项目是php5.6版本,没法使用最新orm,在代码中每处理1个商...