理解抽象类最快的方法就是使用场景,最近在看布尔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(){
}
}
开启错误提示代码:ini_set("display_errors", "On"); error_reporting(E_ALL | E_STRICT);关闭错误提示代码:error_reporting(E_ALL ^&n...
开发com组件可以用c++,vc++,net,我比较熟悉net,演示用dnet(1).创建项目:启动vs2017,新建项目,选择Visual C# ->Windows桌面->类库通用windows(2). 修改Com项目:点击 项目->项目属性,再点击应用程序->程序集信息,...
使用php函数array_multisort()即可实现和SQL一样的order by排序. 例如我们需要对会员表按照主键降序排列,年龄升序排列://会员表数据 $list = []; $list[] = ['mid' =>&n...
(1).前端文件:<form action="upload.php" method="post" enctype="multipart/form-data"> &...
ThinkPHP中有一个debug调试功能,能输出报错文件的信息,并能看到这个函数被哪些函数调用,从框架的启动开始记录,特别方便调试。于是研究了下它的底层给予了实现。<?php //--框架核心--Start //框架内置错误处理 function errDealWith($er...
Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者(publisher),订阅者(subscriber)和频道(channel)。 发布者和订阅者都是Redis客户端,Channel则为Redis服务器端,发布者将消息发送到某个的频道,订阅了这个...