Magento模型不会保存值

Chr*_*ach 10 php mysql model module magento

我正在研究一个保存到自定义表的后端模块.我的问题是我已经为这个表添加了字段,因为我一直在处理它,新添加的字段不会保存模型 - > Save()函数.

我已经完全删除了模块和树脂,让它从头开始创建我的自定义表,以防它有一些我不知道的内部字段数,但仍然是相同的结果.

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

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

结果

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)
Run Code Online (Sandbox Code Playgroud)

一切看起来都很好.当我检查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 |
|-----------------------------------------------------------------------------------------------------------|
Run Code Online (Sandbox Code Playgroud)

我还尝试手动将其他字段插入到数据库表中,如"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;
Run Code Online (Sandbox Code Playgroud)

无论我尝试什么,都不会保存国家代码.我还尝试将teh varchar设置为大于2,将名称切换为country_code(包含国家/地区保留或其他内容).似乎没有任何帮助.

Ros*_* II 33

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

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

<config>
    <global>
        ...
        <cache>
            <backend>Zend_Cache_Backend_BlackHole</backend>
        </cache>
        ...
Run Code Online (Sandbox Code Playgroud)

要刷新包含表结构的缓存,请进入Admin系统,然后选择System> Cache Management> Flush Cache Storage(不是Flush Magento Cache!).这将删除中的文件var/cache.

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

$ sudo rm -fr /path/to/your/magento/installation/var/cache/*
Run Code Online (Sandbox Code Playgroud)


小智 5

据我所知 - Magento以某种方式缓存数据库结构.所以只要Flush Magento Cache应该有所帮助

  • 不幸的是,这个答案是不正确的.[Flush Magento Cache]不会删除`var/cache`中的表结构缓存文件,只有[Flush Cache Storage]选项会这样做. (2认同)