Odoo。用关系导入数据

时间:2015-11-12 10:20:43

标签: openerp odoo-9

我需要xml中的导入员工( hr.employee 对象)并将其与用户( res.users 对象)和联系人( res.partner)联系起来对象)。与用户工作的关系良好(导入后的屏幕下方)。

enter image description here

但我的联系人有问题。当系统导入用户时,她自动创建适用于用户的新联系人。如果我不知道ID,我该如何将这种联系与员工联系起来?

enter image description here

我尝试将联系人记录添加到xml文件并设置关系。但在这种情况下,系统会创建2个联系人其中一个与用户无关。

这是我的xml,用于从我的模块导入。

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data noupdate="1">
        <record id="user_test" model="res.users">
            <field name="name">My Name</field>
            <field name="login">my_name</field>
            <field name="password">1111</field>
        </record>
        <!-- I tried create contact like this...
             but then will be created 2 contacts
             instead 1 + one of them is not related with user -->

        <!--<record id="contact_test" model="res.partner">-->
            <!--<field name="name">My Name</field>-->
            <!--<field name="user_id" ref="user_test"/>-->
        <!--</record>-->
        <record id="employee_test" model="hr.employee">
            <field name="name">My Name</field>
            <field name="work_email">my_name@gmail.com</field>
            <field name="user_id" ref="user_test"/>
        </record>
    </data>
</openerp>

所以,我的问题是:我如何设置联系人(由用户自动创建)给员工?

2 个答案:

答案 0 :(得分:1)

试试这个:

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data noupdate="1">

        <record id="contact_test" model="res.partner">
            <field name="name">My Name</field>
        </record>

        <record id="user_test" model="res.users">
            <field name="name">My Name</field>
            <field name="login">my_name</field>
            <field name="password">1111</field>
            <field name="partner_id ref="contact_test"/>
        </record>

        <record id="employee_test" model="hr.employee">
            <field name="name">My Name</field>
            <field name="work_email">my_name@gmail.com</field>
            <field name="user_id" ref="user_test"/>
            <field name="partner_id" ref="contact_test"/>
        </record>
    </data>
</openerp>

答案 1 :(得分:0)

此解决方案:

<?xml version="1.0" encoding="utf-8"?>
<openerp>
    <data noupdate="1">
        <!-- at first create contact -->
        <record id="contact_test" model="res.partner">
            <field name="name">My Name</field>
        </record>
        <record id="user_test" model="res.users">
            <field name="name">My Name</field>
            <field name="login">my_name</field>
            <field name="password">1111</field>
            <!-- relation between user and contact -->
            <field name="partner_id" ref="contact_test"/>
        </record>
        <record id="employee_test" model="hr.employee">
            <field name="name">My Name</field>
            <field name="work_email">my_name@gmail.com</field>
            <field name="user_id" ref="user_test"/>
            <!-- relation employee and contact -->
            <field name="address_home_id" ref="contact_test"/>
        </record>
    </data>
</openerp>

在这种情况下,将创建1个联系人,1个用户和1个员工。员工与联系人有关系。