Odoo 中文社区

    • 注册
    • 登录
    • 搜索
    • 版块
    • 标签
    • 热门
    • 用户
    • 群组

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

    由于系统升迁的原因,本论坛部分较早期的内容存在格式和链接损坏失效的问题,并非本论坛系统本身的缺陷,望谅解

    本社区没有维护任何QQ群讨论组,任何与本社区同名的QQ群讨论组的言论与本社区无关!

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

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

    [SOLVED] 继承添加 many2one 字段

    Odoo 开发与实施交流
    3
    5
    5262
    正在加载更多帖子
    • 从旧到新
    • 从新到旧
    • 最多赞同
    回复
    • 在新帖中回复
    登录后回复
    此主题已被删除。只有拥有主题管理权限的用户可以查看。
    • Y
      yurenjimi 最后由 编辑

      参考<br / http://simahawk.wordpress.com/2010/10/04/openerp-how-to-add-a-custom-field-to-an-object/ br / http://www.openerp.com/forum/topic7320.html br />
      写了一个模块 purchase_discount.zip

      purchase_discount.py:

      <br />from osv import fields, osv<br /><br />class purchase_order_line(osv.osv):<br />&nbsp; &nbsp; _inherit = &quot;purchase.order.line&quot;<br />&nbsp; &nbsp; _columns = { <br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &#039;test&#039;: fields.char(&#039;TEST&#039;, size=30, help=&quot;Inherited field&quot;),<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &#039;x_ref&#039;: fields.many2one(&#039;hr.employee&#039;, &#039;XRef.&#039;), [color=red]# 问题出现在这里 x_ 前缀[/color]<br />&nbsp; &nbsp; }&nbsp;  <br />purchase_order_line() <br /><br />
      



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

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

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

      Thanks !

      1 条回复 最后回复 回复 引用 0
      • mrshelly
        mrshelly 最后由 编辑

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

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

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

        1 条回复 最后回复 回复 引用 0
        • digitalsatori
          digitalsatori 管理员 最后由 编辑

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

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

          【上海先安科技】(tony AT openerp.cn)

          1 条回复 最后回复 回复 引用 0
          • Y
            yurenjimi 最后由 编辑

            Thanks digitalsatori & mrshelly !

            果然是x_ 的原因.

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

            1 条回复 最后回复 回复 引用 0
            • First post
              Last post