我正在处理保存到自定义表的后端模块。我的问题是我已经在这个表格中添加了字段,因为我一直在处理它,新添加的字段不会使用模型 - > 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。
对我而言,看起来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
(保留国家/地区或其他内容)。似乎没有任何帮助。
答案 0 :(得分:33)
禁用Magento管理系统中的缓存选项 NOT 禁用所有缓存。 Magento仍然在Magento的根文件夹下的var/cache/
目录中缓存表结构,语言环境数据等(这是 NOT /var/cache
)。
要停用所有缓存,请将以下<cache>
条目添加到<global>
的{{1}}部分:
app/etc/local.xml
要刷新包含表结构的缓存,请进入Admin系统,然后选择System&gt;缓存管理&gt;刷新缓存存储(不刷新Magento缓存!)。这将删除<config>
<global>
...
<cache>
<backend>Zend_Cache_Backend_BlackHole</backend>
</cache>
...
中的文件。
您还可以通过命令行刷新缓存:
var/cache
答案 1 :(得分:5)
据我所知 - Magento以某种方式缓存数据库结构。所以只要Flush Magento Cache应该帮助
答案 2 :(得分:0)
1 另请注意,在我的情况下,我只是忘了我使用的是REDIS缓存,所以如果您使用它,请不要忘记删除此缓存!