大话设计模式-抽象工厂模式-简单工厂模式结合

本文展示了如何使用SQL Server和Access数据库进行User表和Department表的操作,包括插入记录和获取记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//User表
class User {
	private $id;
	private $name;

	public function __set($key, $value) {
		$this->$key = $value;
	}

	public function __get($key) {
		if(isset($this->$key)) {
			return $this->$key;
		} else {
			return NULL;
		}
	}
}

//Department表
class Department {
	private $id;
	private $name;

	public function __set($key, $value) {
		$this->$key = $value;
	}

	public function __get($key) {
		if(isset($this->$key)) {
			return $this->$key;
		} else {
			return NULL;
		}
	}
}

//User表操作接口
interface IUser {
	function insert($user);

	function getUser($id);
}

//SqlServer
class SqlServerUser implements IUser {
	public function insert($user) {
		echo '在SQL Server中给User表增加一条记录。';
	}

	public function getUser($id) {
		echo '在SQL Server中根据ID得到User表一条记录。';
		return null;
	}
}

//Access
class AccessUser implements IUser {
	public function insert($user) {
		echo '在Access中给User表增加一条记录。';
	}

	public function getUser($id) {
		echo '在Access中给User表增加一条记录。';
	}
}

//Department表操作
interface IDepartment {
	function insert($department);

	function getDepartment($id);
}

//SqlServer
class SqlServerDepartment implements IDepartment {
	public function Insert($department) {
		echo '在SQL Server中给Department表增加一条记录';
	}

	public function getDepartment($id) {
		echo '在SQL Server中根据ID得到Department表一条记录';
	}
}

//Access
class AccessDepartment implements IDepartment {
	public function insert($department) {
		echo '在Access中给Department表增加一条记录';
	}

	public function getDepartment($id) {
		echo '在Access中根据ID得到Department表一条记录';
		return null;
	}
}

//配置数据库连接方式
define('DB','SqlServer');

//数据库类(代替工厂类)
class DataAccess {
	private static $db = DB;

	public static function createUser() {
		$className = self::$db.'User';
		return new $className;
	}

	public static function createDepartment() {
		$className = self::$db.'Department';
		return new $className;
	}
}

$user = new User();
$dept = new Department();

$iu = DataAccess::createUser();

$iu->insert($user);
$iu->getUser(1);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值