php mysql orm_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

//使用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" => "bar@abc.com"

]);

$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语句

在select、get、insert、update等方法前面加上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 实现来和数据库的互动。 每个数据库表对应一个模型文件。

自主封装的PHP ORM框架,面向对象的PDO数据库操作,API框架,支持Get/Post/Put/Delete多种请求方式。 代码示例: <?php use Models\User; require '../application.php'; require '../loader-api.php'; //适合查询,如:获取用户列表或者单个用户信息 execute_request(HttpRequestMethod::Get, function() { $action = request_action(); //判断是否存在 if ($action == 1) { list($type, $value) = filter_request(array( request_int('type', 1, 2, 3), //1.用户名 2.邮箱 3.手机号 request_string('value'))); $type_field_map = array( 1 => User::$field_username, 2 => User::$field_email, 3 => User::$field_phone ); if ($type == 2 && !is_email($value) || $type == 3 && !is_mobilephone($value)) { die_error(USER_ERROR, $type_field_map[$type]['name'] . '格式无效'); } $user = new User(); $user->set_where_and($type_field_map[$type], SqlOperator::Equals, $value); $result = $user->exists(create_pdo()); echo_result($result ? 1 : 0); //存在返回1,不存在返回0 } //查询单条信息 if ($action == 2) { list($userid) = filter_request(array( request_userid())); //查询单条数据 $user = new User($userid); //set_query_fields可以指定查询字段,下面两种写法均可 //$user->set_query_fields('userid, username, email'); //$user->set_query_fields(array(User::$field_userid, User::$field_username, User::$field_email)); //还可设置where条件进行查询 //$user->set_where_and(User::$field_status, SqlOperator::Equals, 3); //$user->set_where_and(User::$field_truename, SqlOperator::IsNullOrEmpty); //$user->set_where_and(User::$field_age, SqlOperator::In, array(27, 29)); //$user->set_where_and(User::$field_regtime, SqlOperator::LessThan, '-6 month'); //创建数据库连接 $db = create_pdo(); $result = $user->load($db, $user); //也可以用Model类的静态方法 //$result = Model::load_model($db, $user, $user); if (!$result[0]) die_error(PDO_ERROR_CODE, '获取用户信息时数据库错误'); if (!$user) di
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值