Odoo中文社区可以通过以下三个域名访问:shine-it.net , odoocn.org,odoo.net.cn

原论坛用户的基本信息和发帖这里都予以保留,请注意:原论坛用户无需重新注册新用户,但是您的密码需要重置

开发人员可以登录gitter讨论组: http://gitter.im/odoo-china/Talk, 需要github账号

如果您登录系统碰到问题,请在微信公众号留言:

[SOLVED] 继承添加 many2one 字段



  • 参考
    http://simahawk.wordpress.com/2010/10/04/openerp-how-to-add-a-custom-field-to-an-object/
    http://www.openerp.com/forum/topic7320.html

    写了一个模块 purchase_discount.zip

    purchase_discount.py:
    [code]
    from osv import fields, osv

    class purchase_order_line(osv.osv):
        _inherit = "purchase.order.line"
        columns = {
                'test': fields.char('TEST', size=30, help="Inherited field"),
                'x_ref': fields.many2one('hr.employee', 'XRef.'), [color=red]# 问题出现在这里 x
    前缀[/color]
        } 
    purchase_order_line()

    [/code]

    安装模块后, 在客户端 Administration-> Customization->Database Structure-> Objects-> purchase.order.line : 可以看见test 和 x_ref 字段已经新"添加"

    但是用pgadmin3 查看purchase_order_line, 却只有test 插入表中, x_ref 却没有成功.

    在代码上还有要注意的地方么?
    卸载模块后怎么才能让新添加的字段 test 也跟着删除?

    Thanks !



  • 参考
    http://simahawk.wordpress.com/2010/10/04/openerp-how-to-add-a-custom-field-to-an-object/
    http://www.openerp.com/forum/topic7320.html

    写了一个模块 purchase_discount.zip

    purchase_discount.py:
    [code]
    from osv import fields, osv

    class purchase_order_line(osv.osv):
        _inherit = "purchase.order.line"
        columns = {
                'test': fields.char('TEST', size=30, help="Inherited field"),
                'x_ref': fields.many2one('hr.employee', 'XRef.'), [color=red]# 问题出现在这里 x
    前缀[/color]
        } 
    purchase_order_line()

    [/code]

    安装模块后, 在客户端 Administration-> Customization->Database Structure-> Objects-> purchase.order.line : 可以看见test 和 x_ref 字段已经新"添加"

    但是用pgadmin3 查看purchase_order_line, 却只有test 插入表中, x_ref 却没有成功.

    在代码上还有要注意的地方么?
    卸载模块后怎么才能让新添加的字段 test 也跟着删除?

    Thanks !



  • 1 x_ref 应该也会添加才对... 如果没有添加.那你的这两个字段应该不是一次性添加的.或者你先增加了 test 字段.后面才增加的x_ref.

    2 卸载模块是不会删除字段的... 这一块OE弄得比较复杂... 建议手工去数据库里修正. 不然数据库里的数据会乱七八糟的...

    总体上来讲..OE的模块更新 是有很多要注意的地方. 不推荐使用模块更新.而是手动更新. .. 手动去数据库里添加字段  view wizard workflow report 等.


  • 管理员

    @yurenjimi
    这个问题与继承字段的类型没有关系,而与你所起的字段名有关。‘x_'打头的字段名是'custom field' 专属的,也就是你在openerp系统管理-自定义中所创建的字段,你应该注意到在这里面创建的字段,字段名都被强制使用'x_'打头,并且将字段的state强制设为‘manual’,在这里创建的字段只会保存到'ir_model_fields'表中而不会创建到所属model对应的表中。

    只要将名字改成非'x_'起头,你的问题应该就解决了



  • Thanks digitalsatori & mrshelly !

    果然是x_ 的原因.

    新增的字段可以到数据表删除,但是在数据依然残留在 Administration-> Customization->Database Structure-> Fields。


登录后回复
 

与 Odoo 中文社区 的连接断开,我们正在尝试重连,请耐心等待