1

我在任何地方都找不到many-to-manyxml数据中播种的任何示例OpenERP,有谁知道这是否可行,如果可以,怎么办?我开始one2many使用 ref 属性,但没有M2M. openerp 帮助站点也没有答案。

谢谢!伊恩

4

2 回答 2

5

要了解如何为 many2many 关系指定数据,您可能需要查看此文档:

https://doc.openerp.com/v6.0/developer/2_5_Objects_Fields_Methods/methods.html/#osv.osv.osv.write

例如,下面给出了一个 id 列表的引用:

[(6, 0, [id1, id2, id3, ])]

对于在 XML 文件中使用 many2many 关系,我建议阅读以下内容:

https://doc.openerp.com/5.0/developer/5_16_data_serialization/xml_serialization/

让我们以下面的例子来说明你的情况。由于您没有向我们提供代码示例,因此假设我们在新的 test_module 中有以下 2 个对象:

import netsvc
import pooler
from osv import fields, osv

class group(osv.osv):
    _name = 'test_module.group'
    _columns = {
        'name': fields.char("Name", size=128,),
        }
group()

class user(osv.osv):
    _name = 'test_module.user'
    _columns = {
        'name': fields.char("Name", size=128,),
        'group_ids': fields.many2many('test_module.group',
                                      'test_module_user_group_rel',
                                      'user_id', 'group_id', 'Groups'),

user()

现在我们可以创建一个demo.xml文件来在安装和更新时填充数据库。此示例 XML 包含 4 个组和 2 个用户的记录。每个用户都与两个不同的组相关:

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data>
        <record id="group_1" model="test_module.group">
            <field name="name" eval="'Group 1'"/>
        </record>
        <record id="group_2" model="test_module.group">
            <field name="name" eval="'Group 2'"/>
        </record>
        <record id="group_3" model="test_module.group">
            <field name="name" eval="'Group 3'"/>
        </record>
        <record id="group_4" model="test_module.group">
            <field name="name" eval="'Group 4'"/>
        </record>

        <record id="user_1" model="test_module.user">
            <field name="name" eval="'User 1'"/>
            <field name="group_ids"
                   eval="[(6, 0, [group_1, group_3, ])]"/>
        </record>
        <record id="user_2" model="test_module.user">
            <field name="name" eval="'User 2'"/>
            <field name="group_ids"
                   eval="[(6, 0, [group_2, group_3, ])]"/>
        </record>
    </data>
</openerp>
于 2014-01-19T09:01:38.633 回答
1

只是为了添加到 Andrei 的答案 - 在 Odoo 8 中 - 如果您使用来自另一个模块的 xml id - 您需要在 eval 语句中为 id 添加前缀ref():

eval="[(6, 0, [ref('module_name.xml_id'), ref('module_name.xml_id')])]"/>

刚刚从源代码中的 eval 使用示例中发现了这一点 - 并认为它可能对某人有用。

我不确定这是否也适用于与 eval 相同的模块中的 xml id - 或者它是否特定于 Odoo 8。

于 2016-01-14T11:42:51.070 回答