【问题标题】:Cache table values globally in laravel在 laravel 中全局缓存表值
【发布时间】:2017-05-03 20:19:41
【问题描述】:

我有一张桌子:型号为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') }}

没有任何回报。

【问题讨论】:

  • 由于remember 是一种获取值的方式 - 如果不存在默认值,则可能是早期测试中已经存在的值(例如)。可能值得重新启动服务器(如果可能),看看它是否仍然发生。
  • 我尝试了一切,它没有在视图中返回任何值。
  • 你试过清除配置缓存php artisan config:clear
  • 感谢您的建议。之前没试过,刚才试过了,还是没有返回值给视图。
  • 当你做{{ dd(config('settings')) }}时你会得到什么?

标签: php laravel caching laravel-5.4


【解决方案1】:

我没有足够的声誉来评论帖子,但这应该可以解决它

替换:

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

与:

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

然后用通常的方式:

php artisan config:clear
php artisan cache:clear

【讨论】:

    【解决方案2】:

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

    php artisan 
    

     php artisan list
    

    它给出了命令列表和解释,对你有很大帮助

    谢谢。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-07-03
      • 2012-11-11
      • 2012-08-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-10-04
      相关资源
      最近更新 更多