gpt4 book ai didi

php - Magento 模型不会保存值

转载 作者:IT王子 更新时间:2023-10-28 23:45:16 25 4
gpt4 key购买 nike

我正在开发一个保存到自定义表格的后端模块。我的问题是我在处理该表时已将字段添加到该表中,新添加的字段不会使用模型 ->Save() 函数保存。

我已经完全删除该模块并重新安装它,让它从头开始创建我的自定义表,以防它有一些我不知道的内部字段计数,但结果仍然相同。

添加我的数据后,我对提交的内容进行 var 转储,如下所示:

$model = Mage::getModel("smsmanager/sms")->addData($post_data)->save();
var_dump($model->getData()); exit;

结果

array
'form_key' => string 'RUGN3fruWobAf8CZ' (length=16)
'message' => string 'adg asdg sad' (length=14)
'country' => string 'SE' (length=2)
'telephone' => string '+46707332290' (length=12)
'type' => int 2
'id' => string '5' (length=1)

一切看起来都很好。当我检查新创建的 ID 为 5 的行时,我得到了这个:

|-----------------------------------------------------------------------------------------------------------|
|id int(11)| type int(11) | telephone varchar(20) | country varchar(2) | message text | date timestamp |
|-----------------------------------------------------------------------------------------------------------|
| 5 | 2 | +46707332290 | NULL | adg asdg sad | 2013-03-19 21:44:51 |
|-----------------------------------------------------------------------------------------------------------|

我还尝试手动将其他字段插入到数据库表中,例如“junkfield”,并使用 $post_data['junkfield'] = "hello"; 添加它,它也得到 null 作为值(value)。

对我来说,Magento 似乎在耍我。违背逻辑。有人对可能出什么问题有另一种看法吗?哦,在我忘记之前,这是我的表格布局:

CREATE TABLE IF NOT EXISTS `sms_entry` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`type` int(11) NOT NULL,
`telephone` varchar(20) DEFAULT NULL,
`country` varchar(2) DEFAULT NULL,
`message` text,
`date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

无论我怎么尝试,它都不会保存国家代码。我还尝试使 teh varchar 大于 2,将名称切换为 country_code(以防国家被保留或其他)。似乎没有任何帮助。

最佳答案

禁用 Magento 管理系统中的缓存选项不会禁用所有缓存。 Magento 仍然在 var/cache/ 中缓存表结构、语言环境数据等。目录,在 Magento 的根文件夹下(不是 /var/cache )。

要禁用所有缓存,请添加以下 <cache>进入<global>app/etc/local.xml :

<config>
<global>
...
<cache>
<backend>Zend_Cache_Backend_BlackHole</backend>
</cache>
...

要刷新包含表结构的缓存,请进入管理系统,然后选择系统 > 缓存管理 > 刷新缓存存储(不是刷新 Magento 缓存!)。这将删除 var/cache 中的文件.

您还可以通过命令行刷新缓存:

$ sudo rm -fr /path/to/your/magento/installation/var/cache/*

关于php - Magento 模型不会保存值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15510422/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com