我有一个CakePHP应用程序,当前通过Azure SQL访问数据库。下面是连接字符串
'Datasources' => [
'default' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Sqlserver',
'persistent' => true,
'host' => 'XXX.database.windows.net',
'port' => '1433',
'encoding' => PDO::SQLSRV_ENCODING_UTF8,
'username' => 'XXX',
'password' => 'XXX',
'database' => 'DBXXX',
'timezone' => 'UTC',
'cacheMetadata' => true,
'quoteIdentifiers' => false,
//'init' => ['SET GLOBAL innodb_stats_on_metadata = 0'],
],
我正在使用数据库会话。
'Session' => [
'defaults' => 'database'
]
我能够连接数据库。但是,我在下面收到此错误,
无法描述会话。它有0列。
Sessions表肯定有列和数据。但我不确定为什么它列出0列?不仅是会话表。我还有其他包含列和数据的表。但它只是声明无法描述tableName。它有0列。有人面临同样的问题吗?
我今天遇到了这个问题,并设法找到了适合我情况的解决方案。对于您或遇到此错误的其他人而言,这可能会有所不同,但这是其中的一个排列,我认为值得记录以供其他人排除。
我在postgres数据库中有一个现有的模式。这填充了种子数据。这两个操作都是独立于CakePHP 3.x执行的。这个模式Cake正在连接到,并且通过Cake生成的API是探索性原型,用于评估是否在我们的项目中继续使用Cake或Laravel,因此,诸如最佳实践以及无法拆除和重新创建和重新填充模式等内容约束我。
Cake有一些相当严格的命名conventions [关于如何遵循'CakePHP约定优于配置'的文档]。我建议阅读有关模型和数据库及其命名约定的部分。最终,这成了我问题的根源。
我一直在通过PowerArchitect生成模式,以加快从概念ERD到DDL SQL脚本的速度,以测试各种工具和框架。这里的问题是,处理实体键名之间的冲突是一件痛苦的事。例如,两个实体都有id
字段。因此,为了快速原型,尽管我更喜欢将它们命名为<table-name>_id
,但我更容易将它们命名为id
。
例如:
我们有两个表 - person
与person_id
PK和user_account
与关键account_id
。我们的FK约束存在于user_account
上(person_id
是user_account
上的FK为1-n)。
我相信我发现的原因是当命令Cake与bin/cake bake all user_account
一起烘烤时,表account_id
PK的蛇形表示蛋糕,account_id
是另一张名为account
的桌子的FK,存在于user_account
桌子上。根据我的理解,如果命名为user_account_id
,也会发生同样的情况。这是当Cannot describe account. It has 0 columns.
在运行时冒泡,因为Cake正在搜索带有account
字段的表id
。
在我的例子中,很容易拆除模式并相应地编辑表名和密钥以更好地满足Cakes约定,然后重新创建并填充它。
如果这不是一个选项,似乎有可能manually map table names to Models ['Table Objects'用于建模数据库实体],或者bake your application in a modular manner [如何用Bake烘焙样板]来更好地控制组件及其依赖性。由于您指定使用的是SQLserver,因此它的约定也可能会干扰Cake的约定。您可能会发现this Github thread与Oracle vs Cake约定引起的错误有关。具体来说,这个答案来自'snelg':
甲骨文的“一切都是大写的!”正在与蛋糕的自动变化发生冲突。如果你尝试烘焙类似“SomeTable”的东西,那么Cake会寻找一个名为“some_table”的表。如果您尝试烘焙“USERS”,那么Cake将查找名为“u_s_e_r_s”的表。只需键入小写的表名即可克服第一个问题。