栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

laravel 4->获取列名

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

laravel 4->获取列名

新答案

在我给出这个答案的时候, Laravel还没有直接做到这一点的方法 ,但是现在您可以:

$columns = Schema::getColumnListing('users');

旧答案

使用属性将不起作用,因为如果您这样做

$model = new ModelName;

您没有为该模型设置任何属性,您将一无所获。

然后仍然没有真正的选择,因此我不得不深入到数据库级别,这是我的baseModel:

<?phpclass baseModel extends Eloquent {    public function getAllColumnsNames()    {        switch (DB::connection()->getConfig('driver')) { case 'pgsql':     $query = "SELECt column_name FROM information_schema.columns WHERe table_name = '".$this->table."'";     $column_name = 'column_name';     $reverse = true;     break; case 'mysql':     $query = 'SHOW COLUMNS FROM '.$this->table;     $column_name = 'Field';     $reverse = false;     break; case 'sqlsrv':     $parts = explode('.', $this->table);     $num = (count($parts) - 1);     $table = $parts[$num];     $query = "SELECt column_name FROM ".DB::connection()->getConfig('database').".INFORMATION_SCHEMA.COLUMNS WHERe TABLE_NAME = N'".$table."'";     $column_name = 'column_name';     $reverse = false;     break; default:      $error = 'Database driver not supported: '.DB::connection()->getConfig('driver');     throw new Exception($error);     break;        }        $columns = array();        foreach(DB::select($query) as $column)        { $columns[] = $column->$column_name;        }        if($reverse)        { $columns = array_reverse($columns);        }        return $columns;    }}

使用它来做:

$model = User::find(1);dd( $model->getAllColumnsNames() );


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/442633.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号