跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • 浅色
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • 深色
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

  1. 主页
  2. 版块
  3. Odoo 开发与实施交流
  4. [SOLVED] 继承添加 many2one 字段

[SOLVED] 继承添加 many2one 字段

已定时 已固定 已锁定 已移动 Odoo 开发与实施交流
5 帖子 3 发布者 6.6k 浏览 1 关注中
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • Y 离线
    Y 离线
    yurenjimi
    发表于 最后由 编辑
    #1

    参考<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
    • M 离线
      M 离线
      mrshelly
      发表于 最后由 编辑
      #2

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

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

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

      1 条回复 最后回复
      0
      • D 离线
        D 离线
        digitalsatori
        管理员
        发表于 最后由 编辑
        #3

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

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

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

        1 条回复 最后回复
        0
        • Y 离线
          Y 离线
          yurenjimi
          发表于 最后由 编辑
          #4

          Thanks digitalsatori & mrshelly !

          果然是x_ 的原因.

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

          1 条回复 最后回复
          0

          你好!看起来您对这段对话很感兴趣,但您还没有一个账号。

          厌倦了每次访问都刷到同样的帖子?您注册账号后,您每次返回时都能精准定位到您上次浏览的位置,并可选择接收新回复通知(通过邮件或推送通知)。您还能收藏书签、为帖子顶,向社区成员表达您的欣赏。

          有了你的建议,这篇帖子会更精彩哦 💗

          注册 登录
          回复
          • 在新帖中回复
          登录后回复
          • 从旧到新
          • 从新到旧
          • 最多赞同


          • 登录

          • 没有帐号? 注册

          • 登录或注册以进行搜索。
          • 第一个帖子
            最后一个帖子
          0
          • 版块
          • 标签
          • 热门
          • 用户
          • 群组