PHP数据库操作:使用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安装:

Copy

composer require catfan/Medoo
composer update

直接下载:
https://github.com/catfan/Medoo/archive/master.zip

开始使用

引入Medoo并配置数据库:

Copy

<?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:

Copy

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

CURD

查询(Read):

Copy

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] 查询条件

示例:

Copy

$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):

Copy

insert($table, $data)

示例:

Copy

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

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

更新(Update):

Copy

update($table, $data, $where)

示例:

Copy

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

删除(Delete):

Copy

delete($table, $where)

示例:

Copy

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

where

聚合查询

Copy

$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,即关联查询。

事务机制

Copy

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

    try{
        $db->insert("account", [
            "name" => "foo",
            "email" => "[email protected]"
        ]);

        $db->delete("account", [
            "user_id" => 2312
        ]);
    }catch(Exception $e){
        // 返回false就会回滚事务
        return false;
    }
});

使用query

可以直接使用SQL。

Copy

//查询
$data = $db->query("SELECT * FROM user")->fetchAll();
print_r($data);

//删除
$db->query("DELETE FROM user where name=‘t5‘ ");

直接使用PDO

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

获取PDO实例:

Copy

$pdo = $db->pdo;

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

Copy

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 — 设置属性

示例:

Copy

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

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

pdo事务:

Copy

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

try{
    //PDO预处理以及执行语句...

    $pdo->commit();//提交事务
}catch(PDOException $e){
    $pdo->rollBack();//事务回滚

    //相关错误处理
    throw $e;
}

使用DEBUG

debug() 打印最终的SQL语句

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

Copy

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

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

Copy

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

var_dump($db->error());

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

Copy

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

var_dump($db->log());

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

Copy

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

var_dump($db->last_query());

Eloquent ORM

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

原文地址:https://www.cnblogs.com/liliuguang/p/11971403.html

时间: 2024-07-30 21:55:28

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

ORM、SQLAlchemy数据库操作

ORM介绍 背景:用底层的sql写的话,相当于通过pymysql 游标的方式连接"http://blog.51cto.com/jacksoner/2113454 ",为了避免把sql语句写死在代码里,有没有一种方法直接把原生sql封装好了并且以你熟悉的方式操作,像面向对象那样? ORM就是对象映射关系程序.相当于ORM帮我们SQL写成类的形式,然后通过类来调用,获取,而不是写底层的sql(insert,update,select)来获取. ORM 相当于把数据库也给你实例化了,在代码操

Django学习【第5篇】:Django之ORM数据库操作

django之ORM数据库操作 一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例化对象 ORM的两大功能: 操作表: - 创建表 - 修改表 - 删除表 操作数据行: - 增删改查 ORM利用pymysql第三方工具链接数据库 Django没办法帮我们创建数据库,只能我们创建完之后告诉它,让django去链接 二.创建表之前的准备工作 一.自己创建数据库

【Django】ORM数据库操作

Django-ORM数据库操作 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例化对象 ORM的两大功能: 操作表: - 创建表 - 修改表 - 删除表 操作数据行: - 增 删 改 查 ORM利用pymysql第三方工具链接数据库 Django默认的是sqlite数据库 将Django数据库修改为mysql: 1.settings.py 配置 DATABASES = {

C# .NET更智能的数据库操作的封装

前述: 对数据库操作的封装,相信网络上已经有一大堆,ORM框架,或者是.NET本身的EF,都很好的支持数据库操作.这篇文章是分享自己所思考的,对数据库操作的简单封装.我对于这篇文章,认为被浏览者所关注重点的是怎么分析设计数据库操作封装,代码是其次.而且,这是我第一篇文章,为了想好怎么实现花了些天,代码是博客发表时现写的.所以我想,使用可能还有bug,而且没有try catch异常的设计. 这个框架我理应做到对数据库无关,无论是哪个数据库都能够使用.不过,重点在于分析,而不是代码.所以,为了更好的

django的模型类管理器-----------数据库操作的封装

模型实例方法 str():在将对象转换成字符串时会被调用. save():将模型对象保存到数据表中,ORM框架会转换成对应的insert或update语句. delete():将模型对象从数据表中删除,ORM框架会转换成对应的delete语句. 模型类的属性 属性objects:管理器,是Manager类型的对象,用于与数据库进行交互. 当没有为模型类定义管理器时,Django会为模型类生成一个名为objects的管理器,自定义管理器后,Django不再生成默认管理器objects. 管理器是D

Android Afinal框架学习(一) FinalDb 数据库操作

框架地址:https://github.com/yangfuhai/afinal 对应源码: net.tsz.afinal.annotation.sqlite.* net.tsz.afinal.db.sqlite.* net.tsz.afinal.db.table.* net.tsz.afinal.utils.ClassUtils.net.tsz.afinal.utils.FieldUtils FinalDb 建库 FinalDb db = FinalDb.create(context, "my

关于Django中的数据库操作API之distinct去重的一个误传

关于Django中的数据库操作API之distinct去重的一个误传 最近在做一个Server的项目,后台框架是Apache mod_wsgi + django.django是一个基于Python的Web开发框架,功能十分强大,至于有多强大,还是读者们自己去体验吧.我在这里要说的一个问题是关于Python的ORM功能的.问题就在django提供的数据库操作API中的distinct()函数,了解SQL语句的读者都应该知道,DISTINCT关键字可以在select操作时去重.django里的这个d

C# SQLite 数据库操作

C# SQLite 数据库操作学习 运行环境:Window7 64bit,.NetFramework4.61,C# 7.0: 编者:乌龙哈里 2017-03-19 参考: SQLite 官网 SQL As Understood By SQLite System.Data.SQLite 菜鸟教程 SQL 教程 章节: 1.下载安装 2.数据类型 3.创建数据库 4.删除数据库 5.创建表 6.删除表 7.查询表结构 8.更改表名 9.增加列(字段) 10.读取创建表的 SQL 语句 11.更改列名

那些年我们学Flask-SQLAlchemy,实现数据库操作,分页等功能

那些年我们学Flask-SQLAlchemy 实现数据库操作,分页等功能  Flask-SQLAlchemy库让flask更方便的使用SQLALchemy,是一个强大的关系形数据库框架,既可以使用orm方式操作数据库,也可以使用原始的SQL命令. Flask-Migrate 是一个数据迁移框架,需要通过Flask-script库来操作. 一.配置Flask-SQLAlchemy 程序使用的数据库地址需要配置在SQLALCHEMY_DATABASE_URI中,SQLALchemy支持多种数据库,配

Spring中使用JdbcTemplate和HibernateTemplate的数据库操作

目前我接触到的Spring的数据库操作主要包括两种,主要使用JdbcTemplate和HibernateTemplate.后者用于结合Hibernate操作. 两者都提供了持久层访问模板化,只需要获得一个SessionFactory就可以执行持久化操作.可以完成增删改查操作. 获取JdbcTemplate和HibernateTemplate的方式有两种 1. 传统的方式 2. 使用JdbcDaoSupport和HibernateDaoSupport获取,其包含两个方法. (1) getHiber