PHP : ActiveRecord实现示例
先简单介绍一下Active Record:
- <?php
- define('DBHOST', 'localhost');
- define('DBUSER', 'root');
- define('DBPASS', '');
- define('DBNAME', 'test');
- define('TABLE_PREFIX', 't_');
- class ActiveRecord {
- private $tablepre;
- private $class;
- private $table;
- private static $link;
- private $data;
- public $primaryKey = 'id';
- public function __construct() {
- $this->tablepre = TABLE_PREFIX;
- $this->class = get_class($this);
- $this->table = $this->tablepre . strtolower($this->class);
- $this->data = array();
- $this->connect();
- }
- private function connect() {
- if(!self::$link) {
- self::$link = mysql_connect(DBHOST, DBUSER, DBPASS);
- mysql_select_db(DBNAME);
- }
- return self::$link;
- }
- public function __set($name, $value) {
- $this->data[$name] = $value;
- }
- private function implodefields($cond) {
- $fields = array();
- foreach($cond as $key => $value) {
- $value = mysql_real_escape_string($value);
- $fields[] = "`$key`='$value'";
- }
- return implode(', ', $fields);
- }
- public function add() {
- $fields = $this->implodefields($this->data);
- $sql = "INSERT INTO `{$this->table}` SET $fields";
- $this->query($sql);
- }
- public function findById($id) {
- $sql = "SELECT * FROM `{$this->table}` WHERE `{$this->primaryKey}`='$id' LIMIT 1";
- $data = $this->getOne($sql);
- return $this->makeObjFromArray($data);
- }
- private function makeObjFromArray($data) {
- $obj = new $this->class;
- foreach($data as $key => $value) {
- $obj->$key = $value;
- }
- return $obj;
- }
- private function query($sql) {
- echo $sql . "\n";
- return mysql_query($sql, self::$link);
- }
- private function getOne($sql) {
- $data = $this->query($sql);
- if($data) {
- $item = mysql_fetch_assoc($data);
- return $item;
- }
- return false;
- }
- }
- class User extends ActiveRecord {
- var $primaryKey = 'id';
- }
- $user = new User();
- $user->name = '热电影';
- $user->email = 'www.redianying.com';
- $user->add();
- $user = $user->findById(1);
- print_r($user);
PHP : ActiveRecord实现示例的更多相关文章
- JFinal之ActiveRecord开发示例
JFinal独创Db + Record模式示例 JFinal配备的ActiveRecord插件,除了实现了类似Rails ActiveRecrod的功能之外,还实现了Db + Record模式,此模式 ...
- Yii 框架学习--01 框架入门
Yii 是一个高性能的,适用于开发 WEB2.0 应用的 PHP 框架. Yii目前有两个主要的版本: 2.0 和 1.1.本文以YII 2.0.7为例. 环境需求 Yii2.0 框架有一些系统上的需 ...
- Yii ActiveRecord 的via和viaTable示例
Yii中,将两个不相关的表利用中间表关联有via和viaTable两种方法,这里通过用户权限查询来进行示例. 关系如上,需要建立三个表 用户表 权限表 用户表 数据: 权限表 数据: 关联表 数据: ...
- ActiveRecord模式整理
DAO Data Access Object,数据访问对象 DAO是一个软件设计的指导原则,在核心J2EE模式中是这样介绍DAO模式的:为了建立一个健壮的J2EE应用,应该将所有对数据源的访问操作抽象 ...
- Padrino 博客开发示例
英文版出处:http://www.padrinorb.com/guides/blog-tutorial 楼主按 拿作者自己的话说:Padrino(谐音:派骓诺)是一款基于Sinatra的优雅的Web应 ...
- Castle ActiveRecord学习实践
Castle是针对.NET平台的一个开源项目,从数据访问框架ORM到IOC容器,再到WEB层的MVC框架.AOP,基本包括了整个开发过程中的所有东西,为我们快速的构建企业级的应用程序提供了很好的服务. ...
- ActiveRecord的生命周期
ActiveRecord的生命周期,通过方法重写和插入我们需要的业务逻辑来达到我们对程序的控制. 示例: 1,beforeSave() public function beforeSave($inse ...
- Castle ActiveRecord学习(三)数据映射及特性描述
Model中的Demo: using Castle.ActiveRecord; using Castle.ActiveRecord.Queries; using System; using Syste ...
- Castle ActiveRecord学习(六)数据验证
参考.来源:http://www.cnblogs.com/Terrylee/archive/2006/04/13/374173.html https://github.com/castleprojec ...
随机推荐
- SHAREPOINT 2013 + PROJECT 2013 资料网站
1.http://technet.microsoft.com/zh-CN/sharepoint 2\ 博客圆专业讲解 http://www.cnblogs.com/jianyus/archive/2 ...
- GPU Instance
http://forum.china.unity3d.com/thread-17131-1-1.html https://docs.unity3d.com/Manual/GPUInstancing.h ...
- 有关fallback diffuse unity的神奇的事情
fallback diffuse 导致tris面片增加 double了 等于又画了一遍 很奇怪(只有一台机器是这样的) 这事情真坑我跟到最后 在一个最简测试场景 fallback diffuse替换成 ...
- Amazon EC2安装mysql多实例并配置主从复制
1.MySQL安装: EC2直接使用yum安装mysql很方便: yum install mysql mysql-server mysql-libs 此处安装了三个包 完事之后可以直接使用 servi ...
- Linux——.bash_profile和.bashrc的区别(如何设置生效)
/etc/profile:此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.并从/etc/profile.d目录的配置文件中搜集shell的设置./etc/bashrc:为每一个运 ...
- 在eclipse导入Java 的jar包的方法 JDBC
在使用JDBC编程时需要连接数据库,导入JAR包是必须的,导入其它的jar包方法同样如此,导入的方法是 打开eclipse 1.右击要导入jar包的项目,点properties 2.左边选择java ...
- 修改注册表实现Windows自动登陆
昨天再修一条case时无意间发现这个case竟然要重启机器,并且要用指定的账户自动登陆Windows.然后就发现了,简单的修改下注册表就可以完成自动登陆了. 首先,在“run”里输入“regedit” ...
- JSON字符串化
1.JSON字符串化 JSON字符串化有2个可选参数,分别是replacer和space. 第一个可选参数replacer,它可以是数组或者函数.用来指定哪些属性被处理,哪些属性被排除. 第二个可选参 ...
- Android-LinearLayout布局技巧(一)
先看2张图 一.5.1寸 二.3.7寸 三.代码 <?xml version="1.0" encoding="utf-8"?> <Linear ...
- EChart-Timeline
timeline-day.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...