在laravel中全局缓存表值

时间:2017-05-03 06:51:23

标签: php laravel caching laravel-5.4

我有一张表:模型Setting

的设置
class Setting extends Model
{
    protected $fillable = [
        'name', 'value',
    ];
}

我创建了一个服务提供SettingsServiceProvider并在app.php

中注册
class SettingsServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap the application services.
     *
     * @return void
     */
    public function boot(Factory $cache, Setting $settings)
    {
        if (\Schema::hasTable('settings')) {
            config()->set('settings', Setting::pluck('value', 'name')->all());
        }
    }

    /**
     * Register the application services.
     *
     * @return void
     */
    public function register()
    {

    }
}

namevalue添加到表settings后,我在视图中调用它:

{{ config('settings.sitename') }}

其中sitename是完全返回值的name字段。

问题: 此方法的问题在于每个页面请求都会进行数据库调用。由于这些设置不是经常更改的,所以我一直在寻找一种方法来将其缓存在laravel缓存中。

我尝试了以下内容:

class SettingsServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap the application services.
     *
     * @return void
     */
    public function boot(Factory $cache, Setting $settings)
    {
        $settings = $cache->remember('settings', 60, function() use ($settings)
        {
        return $settings->pluck('name', 'value')->all();
        });
        config()->set('settings', $settings);

        /* if (\Schema::hasTable('settings')) {
            config()->set('settings', Setting::pluck('value', 'name')->all());
        } */
    }

    /**
     * Register the application services.
     *
     * @return void
     */
    public function register()
    {
        //
    }
}

但是当我尝试将它返回到这样的视图时:

{{ config('settings.sitename') }}

没有任何回报。

2 个答案:

答案 0 :(得分:4)

我没有足够的声誉对帖子发表评论,但这应该解决它

替换:

done

使用:

return $settings->pluck('name', 'value')->all();

然后按照惯例:

return $settings->pluck('value', 'name')->all();

答案 1 :(得分:0)

在命令提示符下, 只需输入

php artisan 

OR

 php artisan list
  

它给出了带有解释的命令列表,帮助你很多

enter image description here

谢谢。