之前我发了一篇博文PHP数据库操作:从MySQL原生API到PDO,向大家展示PHP是如何使用MySQL原生APIMySQLi面向过程MySQLi面向对象PDO操作MySQL数据库的。本文介绍如何使用ORM操作数据库。

什么是ORM呢?引用网友的话:

ORM 对象关系映射,O(Object) 对象,在项目中就是实体,更加精确的来说就是数据Model,也可以说持久化类。R(Relation) 关系数据,M (Mapping)映射,将对象映射到关系数据,将关系数据映射到对象的过程。更加直观理解就是,ORM 就是以OOP思想,产生增删改查SQL语句。

相比PDO,ORM更适合快速开发项目,而不用写SQL语句。下面介绍几个好用的ORM。

Medoo

下文均以版本1.0.2为例。

环境要求

PHP 5.1+, 推荐PHP 5.4+ 且支持PDO.

至少安装了MySQL, MSSQL, SQLite其中一种.

如何安装

Medoo支持Composer安装和直接下载。

使用Composer安装:

composer require catfan/Medoo
composer update

直接下载:

https://github.com/catfan/Medoo/archive/master.zip

开始使用

引入Medoo并配置数据库:

<?php

//使用Composer安装的这样引入
//require 'vendor/autoload.php'; // 直接下载的这样引入
require_once 'medoo.php'; // 初始化
$db = new medoo([
'database_type' => 'mysql',
'database_name' => 'test',
'server' => 'localhost',
'username' => 'root',
'password' => '123456',
'charset' => 'utf8', //可选:端口
'port' => 3306, //可选:表前缀
'prefix' => '', // PDO驱动选项 http://www.php.net/manual/en/pdo.setattribute.php
'option' => [
PDO::ATTR_CASE => PDO::CASE_NATURAL
]
]);

如果是SQLite:

$database = new medoo([
'database_type' => 'sqlite',
'database_file' => 'my/database/path/database.db'
]);

CURD

查询(Read):

select($table, $columns, $where) //获取所有记录
- table [string] 表名
- columns [string/array] 字段
- where (可选) [array] 查询条件 get($table, $columns, $where) //仅获取一条数据 select($table, $join, $columns, $where)
- table [string] 表名
- join [array] 关联查询,如果没有可以忽略
- columns [string/array] 字段
- where (可选) [array] 查询条件

示例:

$user = $db->select('user', '*'); //返回所有数据
$user = $db->get('user', '*'); //返回一条数据
$user = $db->select('user','*', array('name ' => 'joy'));
$user = $db->select('user','name', array('age[>] ' => 20));
$user = $db->select('user',['name','age'], array('age[<=] ' => 20));

新增(Create):

insert($table, $data)

示例:

$db->insert('user', array('name'=> 't3', 'age'=>22)); //返回自增id

注意:如果数据里面包含子数组将会被serialize()序列化, 你可以使用json_encode()作为JSON存储.

更新(Update):

update($table, $data, $where)

示例:

$db->update('user', array('name'=> 't5'), array('id'=> 23)); //返回受影响的行数

删除(Delete):

delete($table, $where)

示例:

$db->update('user',  array('id'=> 23)); //返回受影响的行数

where

聚合查询

$db->has('user',  array('id'=> 23)); //记录是否存在
$db->count('user', array('id[>]'=> 23)); //统计
$db->max('user', 'age', array('gender'=> 1)); //最大值
$db->min('user', 'age', array('gender'=> 2)); //最小值
$db->avg('user', 'age', array('gender'=> 2)); //平均值
$db->sum('user', 'age', array('gender'=> 2)); //求和

以上方法均支持第二个参数是$join,即关联查询。

事务机制

$db->action(function($db) {

    try{
$db->insert("account", [
"name" => "foo",
"email" => "bar@abc.com"
]); $db->delete("account", [
"user_id" => 2312
]);
}catch(Exception $e){
// 返回false就会回滚事务
return false;
}
});

使用query

可以直接使用SQL。

//查询
$data = $db->query("SELECT * FROM user")->fetchAll();
print_r($data); //删除
$db->query("DELETE FROM user where name='t5' ");

直接使用PDO

Medoo是基于PDO的,所以可以直接调用PDO实例。

获取PDO实例:

$pdo = $db->pdo;

接下来,可以使用PDO对象的所有方法了。

1.PDO::beginTransaction — 启动一个事务
2.PDO::commit — 提交一个事务
3.PDO::__construct — 创建一个表示数据库连接的 PDO 实例
4.PDO::errorCode — 获取跟数据库句柄上一次操作相关的 SQLSTATE
5.PDO::errorInfo — 获取错误信息
6.PDO::exec — 执行一条 SQL 语句,并返回受影响的行数
7.PDO::getAttribute — 取回一个数据库连接的属性
*8.PDO::getAvailableDrivers — 返回一个可用驱动的数组(了解即可)
*9.PDO::inTransaction — 检查是否在一个事务内(了解即可)
10.PDO::lastInsertId — 返回最后插入行的ID或序列值
11.PDO::prepare — 创建SQL的预处理,返回PDOStatement对象
12.PDO::query — 用于执行查询SQL语句,返回PDOStatement对象
13.PDO::quote — 为sql字串添加单引号
14.PDO::rollBack — 回滚一个事务
15.PDO::setAttribute — 设置属性

示例:

$stmt = $pdo->query('select * from user limit 2'); //返回一个PDOStatement对象

//$row = $stmt->fetch(); //从结果集中获取下一行,用于while循环
$rows = $stmt->fetchAll(); //获取所有
print_r($rows);

pdo事务:

$pdo->beginTransaction();//开启事务处理

try{
//PDO预处理以及执行语句... $pdo->commit();//提交事务
}catch(PDOException $e){
$pdo->rollBack();//事务回滚 //相关错误处理
throw $e;
}

使用DEBUG

debug() 打印最终的SQL语句

selectgetinsertupdate等方法前面加上debug()方法可以打印SQL语句,程序不会继续运行:

$user = $db->debug()->select('user', '*');
//SELECT "name","age" FROM "user" WHERE "age" <= 20

error() 返回最后一次操作的出错信息

$db->select('user3', '*'); 

var_dump($db->error());

log() 返回所有的SQL查询语句,不影响查询正常执行

$db->select('user', '*'); 

var_dump($db->log());

last_query()log()类似,但仅返回最后一条SQL查询语句,不影响查询正常执行

$db->select('user', '*'); 

var_dump($db->last_query());

Eloquent ORM

Eloquent ORM是Laravel框架使用的ORM。Laravel 的 Eloquent ORM 提供了更优雅的ActiveRecord 实现来和数据库的互动。 每个数据库表对应一个模型文件。

参考:

1、Guidebook - Medoo

http://medoo.in/api/new/

2、Eloquent ORM笔记 - 飞鸿影~ - 博客园

http://www.cnblogs.com/52fhy/p/5277657.html

(未完待续。。。)

PHP数据库操作:使用ORM的更多相关文章

  1. Laravel 数据库操作 Eloquent ORM

    laravel 操作数据库一般都使用它的Eloquent ORM才操作 建立模型 <?php namespace App; use Illuminate\Database\Eloquent\Mo ...

  2. Django进阶Model篇—数据库操作(ORM)

    一.数据库配置 django 默认支持sqlite.mysql.oracle.postgresql数据库,像db2和sqlserver之类的数据库需要第三方的支持,具体详见https://docs.d ...

  3. Laravel 学习笔记之数据库操作——Eloquent ORM

    1. 时间戳 默认情况下在使用ORM操作数据库进行添加.修改数据时, created_at 和 updated_at列会自动存在于数据表中,并显示的是 ‘2017’格式,如果想以 Unix时间戳格式存 ...

  4. Laravel数据库操作 Eloquent ORM

    模型首先在App目录下建立student的文件夹 里面放上 Student.php 且需要继承基类Model //允许批量赋值的字段// protected $fillable = ['name',' ...

  5. golang学习笔记16 beego orm 数据库操作

    golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...

  6. Django 2.0 学习(14):Django ORM 数据库操作(上)

    Django ORM 数据库操作(上) ORM介绍 映射关系: 数据库表名 ---------->类名:数据库字段 ---------->类属性:数据库表一行数据 ----------&g ...

  7. 使用脚本与orm模型交互对数据库操作

    场景:如不想启动服务在框架中查看数据库数据,同时使用ORM框架对数据库操作带来的好处 import os import sys #将脚本所在的工程添加到环境变量 sys.path.append('.. ...

  8. Django 2.0 学习(16):Django ORM 数据库操作(下)

    Django ORM数据库操作(下) 一.增加表记录 对于表单有两种方式: # 方式一:实例化对象就是一条表记录france_obj = models.Student(name="海地&qu ...

  9. Django【第5篇】:Django之ORM数据库操作

    django之ORM数据库操作 一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录-------- ...

随机推荐

  1. BZOJ4350: 括号序列再战猪猪侠

    Description 括号序列与猪猪侠又大战了起来. 众所周知,括号序列是一个只有(和)组成的序列,我们称一个括号 序列S合法,当且仅当: 1.( )是一个合法的括号序列. 2.若A是合法的括号序列 ...

  2. js读写Cookie问题(Cookie存储时长、Cookie存储域)汇总

    在采集网站用户行为数据/使用js对用户行为做交互时,经常会使用到Cookie,了解Js Cookie的读写,以及一些细节,非常重要.   什么是Cookie 所谓Cookie,只是一条极为短小的信息, ...

  3. 如何防止JAVA反射对单例类的攻击?

    在我的上篇随笔中,我们知道了创建单例类有以下几种方式: (1).饿汉式; (2).懒汉式(.加同步锁的懒汉式.加双重校验锁的懒汉式.防止指令重排优化的懒汉式); (3).登记式单例模式; (4).静态 ...

  4. EditPlus 3.1

    User:GNU Serial:918A8-20DD8-44ZA1-B0W4A-13T66

  5. MemCached 安装笔记

    安装步骤: 1. 下载libevent & memcached 源码包 分别把memcached和libevent下载回来,放到 /tmp 目录下: # cd /tmp     # wget ...

  6. new的原罪

    一直以为在开发阶段能够直接调用的,速度而言一定是最优秀的,因为总比后期通过反射之类来调用来得快吧. 下面请看一个SB的例子,重新编译以后,这个类在创建100,000,000实体时居然耗费了16秒的时间 ...

  7. Linux内核分析之扒开系统调用的三层皮(下)

    一.实验内容 1. 通过内核的方式使用系统调用 需要使用的命令 rm menu -rf //强制删除当前menugit clone http://github.com/mengning/menu.gi ...

  8. 第七章 内存管理单元MMU介绍

    7.1 内存管理单元MMU介绍 7.1.1 S3C2410/S3C2440 MMU特性 负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查 特性: 与ARM V4兼容的映射长度.域.访问权 ...

  9. Python成长笔记 - 基础篇 (十三)--堡垒机

    堡垒机架构 堡垒机的主要作用权限控制和用户行为审计,堡垒机就像一个城堡的大门,城堡里的所有建筑就是你不同的业务系统 , 每个想进入城堡的人都必须经过城堡大门并经过大门守卫的授权,每个进入城堡的人必须且 ...

  10. 关于STM32-MDK中preprocessor symbols解释

    preprocessor symbols 是预处理符号的意思,这里相当于宏定义,我们在使用STM32固件库时,由于固件库里面包含的是ST整个系列单片机的定义,如下图 这时在define框中可以作为一个 ...