Magento模型不保存值


Magento model won't save values

我正在研究一个保存到自定义表的后端模块。我的问题是,我已经添加字段到这个表,因为我一直在工作,新添加的字段不会保存与模型-> save()函数。

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

添加我的数据后,我做了一个var dump的提交,像这样:

$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;

无论我怎么尝试,它都不会保存国家代码。我还尝试使varchar大于2,将名称切换为country_code(以防保留国家或其他东西)。

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

要禁用所有缓存,请将以下<cache>条目添加到app/etc/local.xml<global>部分:

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

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

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

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

据我所知- Magento缓存数据库结构。所以刷新Magento缓存会有帮助

+1还请注意,在我的情况下,我只是忘记了我使用REDIS缓存,所以如果你使用这个,不要忘记删除这个缓存!!