6

我发现了这个类似的问题,但我的问题不同。

我将我的 CakePHP 2.2 应用程序移到了另一台服务器上。迁移前没有问题。迁移后大多数事情都可以正常工作。我可以访问我的大多数数据库表等。但是当我尝试访问我的一个表时,我收到了这个错误:

"Error 500: Table stats for model Stat was not found in datasource default."

为了解决这个问题,我检查了这个文件夹:“/app/tmp/cache/models”

在该文件夹中,我的每个表都有一个文件

  • myapp_cake_model_default_mydatabase_table1
  • myapp_cake_model_default_mydatabase_table2
  • myapp_cake_model_default_mydatabase_table3 等。

但是没有统计表的文件。这可能是问题吗?或者我该如何解决这个问题?

(“/app/tmp/cache/models”文件夹的权限为 755)

Database.php我有这个:

public $default = array(
    'datasource' => 'Database/Mysql',
    'persistent' => false,
    'host' => 'localhost',
    'login' => 'myuser',
    'password' => 'mypass',
    'database' => 'mydatabase',
    'prefix' => '',
    'encoding' => 'utf8',
);

编辑:
正如我在 thaJeztah 的回答评论中所指出的,在删除了app/tmp/cache/persistent问题中的所有文件后。CakePHP 创建了新的模型缓存文件并且它工作了。一年后,我发现了真正的问题。问题是设置蛋糕模型文件的明确持续时间。我将清除缓存设置为 +999 天,因此不会重新生成模型文件。在进行模型更改时,您可以为模型缓存清除设置较低的值:

Cache::config('_cake_model_', array(
    'engine' => "File",
    'prefix' => "myapp_". 'cake_model_',
    'path' => CACHE . 'models' . DS,
    'serialize' => ($engine === 'File'),
    'duration' => "+999 days"
));
4

2 回答 2

27

您是否检查过您的数据库,例如在 phpMyAdmin 或 MySql 工作台中?该表是否存在于数据库中?

错误消息表明无法使用默认连接访问该表。有可能该表确实丢失了,或者您用来连接数据库的用户没有该表的正确权限。

如果您从另一台服务器迁移数据库,导入时是否收到错误消息?如果您没有创建包含在事务中的转储,则可能只是部分导入了数据库转储。

[更新]这个建议解决了问题;

从中删除所有文件app/tmp/cache/persistent/app/tmp/cache/models然后启用调试。您的 SQL 日志/调试应该显示 CakePhp 用来检测数据库中是否存在表的查询。您还可以检查 Cake 是否可以毫无问题地写入 tmp 文件

于 2013-02-05T21:00:44.310 回答
0

如果这对 2020 年的任何人都有帮助。即使拥有模型的完全权限,我也遇到了这个问题。我尝试像@theJeztah 建议的那样清除缓存/持久性,但问题仍然存在。最终的工作是切换Configure::write('debug', 0)Configure::write('debug', 2). app/core file大概在调试时它可以更好地清除缓存。

于 2020-12-07T15:27:51.990 回答