1

我正在为 Magento 1.7.0 制作一个自定义模块。我在尝试将数据插入 MySQL 时遇到问题。我从会话中获取用户信息,如下所示:

$customer = Mage::getSingleton('customer/session')->getCustomer(); 
$user_id = $customer->getId();

$user_id现在携带ID当前用户登录到我的 Magento 系统。

基本上问题是,当我尝试将上述 ID 保存在我的自定义表中时,保存在我的表中的值始终为0

以前我在尝试保存另一个整数值时遇到了这个问题,我通过将 MySQL 表列的数据类型从 int(10) 更改为 tinyint(4) 解决了这个问题,但在这种情况下,我不能为用户 ID 这样做。

$model= Mage::getModel('voter/competetion')
    ->setDesignid($designId)
    ->setUserId($user_id)
    ->setVote($vote)
    ->setStartdate($startDate)
    ->save();

MySQL 列名与安装 sql 脚本如下:id、designid、user_id、vote、startdate、enddate

$installer = $this;
$installer->startSetup();

$prefix = Mage::getConfig()->getTablePrefix();

$installer->run("
    CREATE TABLE IF NOT EXISTS ".$prefix."vote_competetion (
        id int(10) NOT NULL AUTO_INCREMENT,
        designid int(10) NOT NULL,
        user_id int(10) NOT NULL,
        vote tinyint(1) NOT NULL,
        startdate datetime NOT NULL,
        enddate datetime NOT NULL,
        PRIMARY KEY (id),
        FOREIGN KEY (designid) REFERENCES ".$prefix."vote_design(id)
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1;
");

Mage::getModel('core/url_rewrite')->setId(null);
$installer->endSetup();

我的 setter 方法名称有问题吗?所有其他值都被正确保存。我真的不知道该怎么办。请帮忙。

我感谢所有的帮助。

谢谢!

4

2 回答 2

3

如果你从一开始就没有 user_id 在表中,你应该清除缓存,因为 Magento 保持它的结构缓存并且不会设置任何新的列数据。

于 2012-05-30T13:28:02.843 回答
0

您在命名用户 ID 字段时出错。在表中它被命名为userid,所以在你的代码中你应该这样称呼它:

$model= Mage::getModel('voter/competetion')
    ->setDesignid($designId)
    ->setUserid($user_id) // notice lowercase "i" here
    ->setVote($vote)
    ->setStartdate($startDate)
    ->save();

或者您可以将表中的字段从userid重命名为user_id

于 2012-05-30T12:25:14.313 回答