`
xieye
  • 浏览: 830767 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2

    博客分类:
  • PHP
阅读更多
我的Eloquent单独使用系列文章
php的db类库Eloquent单独使用系列(1)
php的db类库Eloquent单独使用系列(2) - 分页
php的db类库Eloquent单独使用系列(3) - sql日志
php的db类库Eloquent单独使用系列(4)- 事件监听
php的db类库Eloquent单独使用系列(5)- 模型转数组
php的db类库Eloquent单独使用系列(6)- 一对一关联
php的db类库Eloquent单独使用系列(7)- 一对多关联
php的db类库Eloquent单独使用系列(8)- 多对多关联
php的db类库Eloquent单独使用系列(9)- 多对多关联 - 表关联自身
php的db类库Eloquent单独使用系列(10)- 多对多关联 - 远程一对多
php的db类库Eloquent单独使用系列(11)- 多对多关联 - 添加模型属性
php的db类库Eloquent单独使用系列(12)- 结果集模型转数组 - 2


本系列文章的目的就是脱离laravel环境使用Eloquent,因为它好用
本系列文章所有代码均测试通过。Eloquent版本:5.4.27

本文的目的是彻底把laravel的结果集返回对象改成数组的问题搞定。
网上查阅好像有一种方法是改配置,可是这样的话,会影响全局,不希望如此,
所以单独写了一个查询方法,仅适用于select,并定义了很方便的4种查询方法,这样,eloquent就可以更加通用的使用在除了laravel的各种框架里!!

建表
请自行插入几条数据
CREATE TABLE users (
  id int(11) NOT NULL AUTO_INCREMENT,
  name varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '用户名称',
  PRIMARY KEY (`id`)
)


源代码
主要两个文件,一个是DbSelect类,另外是客户端代码,注意实际使用中,肯定是把db对象的获取单独定义的。
DbSelect.php
<?php

namespace app\lib;


class DbSelect {
    /**
     * 获取常规的数据库查询结果,
     * 假如结果集为空,返回[]
     * 
     * @param \Illuminate\Database\Capsule\Manager $db laravel5框架的Eloquent的DB对象  
     * @param string $sql 查询语句
     * @param array $bind  绑定参数
     * return array 二维数组
     */
    public static function fetchAll($db, $sql, $bind=[]) 
    {
        $result = collect( $db::select($sql,$bind ))->map(function ($v,$k){ 
            return get_object_vars($v);  
        })->toArray() ;
        return $result;
    }
    
    /**
     * 获取数据库查询结果,是单列的,
     * 假如sql语句中包含多列,只取第一列
     * 假如结果集为空,返回[]
     *
     * @param \Illuminate\Database\Capsule\Manager $db laravel5框架的Eloquent的DB对象 
     * @param string $sql 查询语句
     * @param array $bind  绑定参数
     * return array 一维数组
     */
    public static function fetchCol($db, $sql, $bind=[]) 
    {
        $result = collect( $db::select($sql,$bind ))->map(function ($v,$k){ 
            $a = get_object_vars($v);
            foreach ($a as $k2=> $v2) {
                return $v2;
            }
        })->toArray();
        return $result;
    }
    
    /**
     * 获取数据库查询结果,是单个值,标量
     * 假如sql语句中包含多列,只取第一列
     * 假如结果集有多行,只取第一行
     * 假如结果集为空,返回null
     *
     * @param \Illuminate\Database\Capsule\Manager $db laravel5框架的Eloquent的DB对象 
     * @param string $sql 查询语句
     * @param array $bind  绑定参数
     * return mixed 整型|字符串|浮点型
     */
    public static function fetchOne($db, $sql, $bind=[])
    {
        $result = collect( $db::select($sql,$bind ))->map(function ($v,$k){
            if ($k==0) {
                $a = get_object_vars($v);
                foreach ($a as $k2=> $v2) {
                    return $v2;
                }
            }
        })->toArray();
        if ($result) {
            $result = $result[0];
        }else {
            $result = null;
        }
        return $result;
    }
    
    /**
     * 获取数据库查询结果,只取第一行
     * 假如结果集为空,返回null
     *
     * @param \Illuminate\Database\Capsule\Manager $db laravel5框架的Eloquent的DB对象 
     * @param string $sql 查询语句
     * @param array $bind  绑定参数
     * return array 一维数组,对应表中的一行。
     */
    public static function fetchRow($db, $sql, $bind=[])
    {
        $result = collect( $db::select( $sql,$bind ))->map(function ($v,$k){
            if ($k==0){
              return get_object_vars($v);
            }else {
              return null;
            }
        })->toArray() ;
        if ($result) {
            $result = $result[0];
        }else {
            $result = null;
        }
        return $result;
    }
}


客户端代码
<?php
namespace app\control;

use Illuminate\Database\Capsule\Manager;

class Ill7
{
    /**
     * 客户端代码
     */
    public function index() 
    {
        $db = new Manager ();
        $db->addConnection ( [ 
            'driver' => 'mysql',
            'host' => '127.0.0.1',
            'database' => 'test1',
            'username' => 'root',
            'password' => 'root',
            'charset' => 'utf8mb4',
            'collation' => 'utf8mb4_unicode_ci',
            'prefix' => '' 
        ] );
        $db->setAsGlobal ();
        $db->bootEloquent ();
      
        $sql1 = "SELECT id,name FROM users   where id<10 order by id asc limit 2";// 常规无bind
        $sql2 = "SELECT id,name FROM users   where id<10 order by id asc limit ?";//必须带bind
        $sql3 = "SELECT id,name FROM users   where id<0  order by id asc limit 2"; //注定无结果
        
        echo "<h2>select - fetchAll()方法</h2>";
        $result = \app\lib\DbSelect::fetchAll($db, $sql1);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchAll($db, $sql2,[2]);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchAll($db, $sql3);
        var_dump($result);echo "<hr>";
        
        echo "<h2>select - fetchCol()方法</h2>";
        $result = \app\lib\DbSelect::fetchCol($db, $sql1);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchCol($db, $sql2,[2]);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchCol($db, $sql3);
        var_dump($result);echo "<hr>";
        
        echo "<h2>select - fetchOne()方法</h2>";
        $result = \app\lib\DbSelect::fetchOne($db, $sql1);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchOne($db, $sql2,[2]);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchOne($db, $sql3);
        var_dump($result);echo "<hr>";
        
        echo "<h2>select - fetchRow()方法</h2>";
        $result = \app\lib\DbSelect::fetchRow($db, $sql1);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchRow($db, $sql2,[2]);
        var_dump($result);echo "<hr>";
        
        $result = \app\lib\DbSelect::fetchRow($db, $sql3);
        var_dump($result);echo "<hr>";
        
        echo '<br>all ok!';
    }
}


浏览器输出


  • 大小: 40.3 KB
0
0
分享到:
评论

相关推荐

    Laravel开发-eloquent-extended-cast-model

    Eloquent-Extended-Cast-Model 是一个扩展库,它增强了Eloquent模型的特性,允许开发者定义自定义的类型转换,从而能够更加灵活地管理和操作数据。 Eloquent ORM的核心概念包括模型(Model)、迁移(Migration)、...

    Laravel开发-eloquent-uuid-for-key

    1. **安装扩展包**:通常我们可以使用`spatie/laravel-eloquent-has-many-deep`这个扩展包,它为Eloquent提供了对UUID的支持。通过Composer安装: ``` composer require spatie/laravel-eloquent-has-many-deep `...

    Laravel开发-eloquent-single-state-marking-store

    "Laravel开发-eloquent-single-state-marking-store"是一个专为Laravel设计的扩展,旨在支持单一状态标记存储,其灵感来源于Symfony的工作流程组件。这个项目的目标是帮助开发者更好地管理和跟踪对象的状态,特别是...

    Laravel开发-eloquent-extended-cast-model .zip

    这个压缩包“Laravel开发-eloquent-extended-cast-model .zip”很可能包含了一些关于如何扩展Eloquent模型的自定义类型转换(casts)的教程或示例代码。 Eloquent的模型类与数据库表一一对应,每个模型实例代表表中...

    Laravel开发-eloquent-single-table-inheritance

    在Laravel框架中,Eloquent ORM(对象关系映射)是其强大且优雅的数据操作工具。Eloquent提供了许多高级特性,其中包括单表继承(Single Table Inheritance,STI)。本教程将深入探讨如何在Laravel项目中利用...

    Laravel开发-eloquent-model-generator

    Eloquent-Model-Generator工具则简化了在Laravel5项目中创建Eloquent模型的过程,它能根据现有的数据库结构自动生成对应的模型文件,极大地提高了开发效率。 首先,Eloquent Model是Laravel中的数据访问层,每个...

    Laravel开发-eloquent-log-lazy-loading

    默认情况下,Eloquent模型会自动使用延迟加载。例如,如果我们有一个`User`模型,它有一对多的`posts`关系,我们可以通过以下方式获取用户及其文章: ```php $user = User::find(1); foreach ($user-&gt;posts as $...

    ros2-eloquent-20191122-windows-release-amd64.zip

    ROS2系统的核心部分是ROS网络(ROS Graph)。ROS网络是指在ROS系统中不同的节点间相互通信的连接关系。 ROS Graph这里翻译成了ROS网络,因为我觉得Graph更加抽象,而网络的概念更容易帮助理解其内涵。 此资源为github...

    php一些比较常用类库及例子

    在PHP编程中,类库是预定义的一组函数或对象,它们提供了标准功能,以便开发者可以轻松地在项目中重用代码。以下是一些在PHP中常用的类库,以及它们在数据库连接、文件上传和数据过滤等场景中的应用实例。 1. **...

    Laravel开发-eloquent-mongodb-repository

    "Laravel开发-eloquent-mongodb-repository"的主题就是关于如何在Laravel中利用Eloquent ORM来与MongoDB进行交互的实践教程。 首先,我们需要安装Jenssegers/Laravel-MongoDB扩展包,这个扩展提供了Eloquent模型对...

    Laravel开发-eloquent-sortable

    Eloquent提供了简单、直观的方式来处理数据库中的数据,而"eloquent-sortable"则是一个扩展,它为Eloquent模型增加了排序功能,允许我们轻松地对数据库记录进行排序。这个扩展的使用大大简化了在应用程序中实现动态...

    eloquent-model-generator:雄辩的模型生成器

    composer require krlove/eloquent-model-generator --dev 步骤2.注册GeneratorServiceProvider : 'providers' =&gt; [ // ... Krlove \ EloquentModelGenerator \ Provider \ GeneratorServiceProvider ::class, ...

    Laravel开发-eloquent-base-model

    "Laravel开发-eloquent-base-model" 主题聚焦于Eloquent ORM中的基础模型(Base Model),它是所有自定义模型类的基类,为开发者提供了许多便利的功能和接口。 Eloquent Base Model位于`Illuminate\Database\...

    Laravel开发-laravel-eloquent-mysqli

    总之,`laravel-eloquent-mysqli` 项目旨在帮助开发者了解和实践在 Laravel 中使用 mysqli 驱动进行数据库操作,这对于那些需要充分利用 MySQL 扩展特性的项目来说,是一个有价值的资源。在实际开发中,根据项目需求...

    Laravel开发-eloquent-search-map

    composer require arcanedev/eloquent-search-map ``` 然后,在你的模型中引入并使用`Arcanedev\\Searchable\\Searchable` Trait: ```php use Arcanedev\\Searchable\\Searchable; class YourModel extends ...

    Laravel开发-eloquent-state-machine

    在Laravel框架中,Eloquent ORM(对象关系映射)是用于数据库操作的强大工具,而...通过`eloquent-state-machine-master`这个项目,我们可以学习并实践如何在Laravel项目中有效地集成和使用Eloquent State Machine。

    Laravel开发-laravel-eloquent-filter

    Eloquent模型可以使用查询构建器的方法,如`where`, `orWhere`, `whereIn`等,来构造复杂的SQL查询。这些方法使得在代码中处理数据库查询变得更加简单易读。 3. **Eloquent Filter原理** Eloquent Filter的基本...

    eloquent-sortable, Eloquent模型的可以排序行为.zip

    eloquent-sortable, Eloquent模型的可以排序行为 Eloquent模型的排序行为 这个包提供了一个特性,它向一个有说服力的模型添加了可以排序的行为。模型新记录的order列的值由模型 1的所有记录的order列的最大值决定。...

    Laravel开发-eloquent-postgres-uuids

    本项目"Laravel开发-eloquent-postgres-uuids"专门探讨了如何在PostgreSQL数据库中使用UUID作为Eloquent模型的主键。 首先,我们要了解Eloquent ORM,它是Laravel框架的核心部分,为开发者提供了简洁、优雅的方式来...

    Laravel开发-eloquent-custom

    2. **扩展查询构造器**:我们可以通过门面(Facade)`DB`或Eloquent模型的`newQuery()`方法,自定义查询构建器的方法。例如,添加一个`betweenDates`查询方法: ```php public function scopeBetweenDates($query, ...

Global site tag (gtag.js) - Google Analytics