Skip ke Konten
Odoo Menu
  • Login
  • Uji coba gratis
  • Aplikasi
    Keuangan
    • Akuntansi
    • Faktur
    • Pengeluaran
    • Spreadsheet (BI)
    • Dokumen
    • Tanda Tangan
    Sales
    • CRM
    • Sales
    • POS Toko
    • POS Restoran
    • Langganan
    • Rental
    Website
    • Website Builder
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Rantai Pasokan
    • Inventaris
    • Manufaktur
    • PLM
    • Purchase
    • Maintenance
    • Kualitas
    Sumber Daya Manusia
    • Karyawan
    • Rekrutmen
    • Cuti
    • Appraisal
    • Referensi
    • Armada
    Marketing
    • Social Marketing
    • Email Marketing
    • SMS Marketing
    • Acara
    • Otomatisasi Marketing
    • Survei
    Layanan
    • Project
    • Timesheet
    • Layanan Lapangan
    • Meja Bantuan
    • Planning
    • Appointment
    Produktivitas
    • Discuss
    • Approval
    • IoT
    • VoIP
    • Pengetahuan
    • WhatsApp
    Aplikasi pihak ketiga Odoo Studio Platform Odoo Cloud
  • Industri-Industri
    Retail
    • Toko Buku
    • Toko Baju
    • Toko Furnitur
    • Toko Kelontong
    • Toko Hardware
    • Toko Mainan
    Makanan & Hospitality
    • Bar dan Pub
    • Restoran
    • Fast Food
    • Rumah Tamu
    • Distributor Minuman
    • Hotel
    Real Estate
    • Agensi Real Estate
    • Firma Arsitektur
    • Konstruksi
    • Estate Management
    • Perkebunan
    • Asosiasi Pemilik Properti
    Konsultansi
    • Firma Akuntansi
    • Mitra Odoo
    • Agensi Marketing
    • Firma huku
    • Talent Acquisition
    • Audit & Sertifikasi
    Manufaktur
    • Tekstil
    • Logam
    • Perabotan
    • Makanan
    • Brewery
    • Corporate Gift
    Kesehatan & Fitness
    • Sports Club
    • Toko Kacamata
    • Fitness Center
    • Wellness Practitioners
    • Farmasi
    • Salon Rambut
    Perdagangan
    • Handyman
    • IT Hardware & Support
    • Sistem-Sistem Energi Surya
    • Pembuat Sepatu
    • Cleaning Service
    • Layanan HVAC
    Lainnya
    • Organisasi Nirlaba
    • Agen Lingkungan
    • Rental Billboard
    • Fotografi
    • Penyewaan Sepeda
    • Reseller Software
    Browse semua Industri
  • Komunitas
    Belajar
    • Tutorial-tutorial
    • Dokumentasi
    • Sertifikasi
    • Pelatihan
    • Blog
    • Podcast
    Empower Education
    • Program Edukasi
    • Game Bisnis 'Scale Up!'
    • Kunjungi Odoo
    Dapatkan Softwarenya
    • Download
    • Bandingkan Edisi
    • Daftar Rilis
    Kolaborasi
    • Github
    • Forum
    • Acara
    • Terjemahan
    • Menjadi Partner
    • Layanan untuk Partner
    • Daftarkan perusahaan Akuntansi Anda.
    Dapatkan Layanan
    • Temukan Mitra
    • Temukan Akuntan
    • Temui penasihat
    • Layanan Implementasi
    • Referensi Pelanggan
    • Bantuan
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Dapatkan demo
  • Harga
  • Bantuan

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Akuntansi
  • Inventaris
  • PoS
  • Project
  • MRP
All apps
Anda harus terdaftar untuk dapat berinteraksi di komunitas.
Semua Post Orang Lencana-Lencana
Label (Lihat semua)
odoo accounting v14 pos v15
Mengenai forum ini
Anda harus terdaftar untuk dapat berinteraksi di komunitas.
Semua Post Orang Lencana-Lencana
Label (Lihat semua)
odoo accounting v14 pos v15
Mengenai forum ini
Help

how do i save a m2m field?

Langganan

Dapatkan notifikasi saat terdapat aktivitas pada post ini

Pertanyaan ini telah diberikan tanda
createv7many2manym2m
2 Replies
11222 Tampilan
Avatar
AJ Schrafel Paper Corp

I would like to select and save a group of partners as a many2many field, and then use that field to generate a set of actions. I can get the XML to display and select the partners that i want to save, but i cannot get the m2m field to write in the database. I know that i have to write a create function to save the m2m relationship in my custom module, but i cannot figure out what i am doing wrong.

Can someone please point me to an example of how to write a create function?

I am getting the following error:

    Client Traceback (most recent call last):
  File "/opt/openerp/web/addons/web/http.py", line 204, in dispatch
    response["result"] = method(self, **self.params)
  File "/opt/openerp/web/addons/web/controllers/main.py", line 1129, in call_kw
    return self._call_kw(req, model, method, args, kwargs)
  File "/opt/openerp/web/addons/web/controllers/main.py", line 1121, in _call_kw
    return getattr(req.session.model(model), method)(*args, **kwargs)
  File "/opt/openerp/web/addons/web/session.py", line 43, in proxy
    result = self.proxy.execute_kw(self.session._db, self.session._uid, self.session._password, self.model, method, args, kw)
  File "/opt/openerp/web/addons/web/session.py", line 31, in proxy_method
    result = self.session.send(self.service_name, method, *args)
  File "/opt/openerp/web/addons/web/session.py", line 104, in send
    raise xmlrpclib.Fault(openerp.tools.ustr(e), formatted_info)


Server Traceback (most recent call last):
  File "/opt/openerp/web/addons/web/session.py", line 90, in send
    return openerp.netsvc.dispatch_rpc(service_name, method, args)
  File "/opt/openerp/server/openerp/netsvc.py", line 293, in dispatch_rpc
    result = ExportService.getService(service_name).dispatch(method, params)
  File "/opt/openerp/server/openerp/service/web_services.py", line 626, in dispatch
    res = fn(db, uid, *params)
  File "/opt/openerp/server/openerp/osv/osv.py", line 188, in execute_kw
    return self.execute(db, uid, obj, method, *args, **kw or {})
  File "/opt/openerp/server/openerp/osv/osv.py", line 131, in wrapper
    return f(self, dbname, *args, **kwargs)
  File "/opt/openerp/server/openerp/osv/osv.py", line 197, in execute
    res = self.execute_cr(cr, uid, obj, method, *args, **kw)
  File "/opt/openerp/server/openerp/osv/osv.py", line 185, in execute_cr
    return getattr(object, method)(cr, uid, *args, **kw)
  File "/opt/openerp/server/openerp/osv/orm.py", line 4148, in write
    for sub_ids in cr.split_for_in_conditions(ids):
  File "/opt/openerp/server/openerp/sql_db.py", line 258, in split_for_in_conditions
    return tools.misc.split_every(self.IN_MAX, set(ids))
TypeError: unhashable type: 'dict'

How do i properly save a m2m field?

Here is my test code:

m2m_test.py

import netsvc
import tools
import time 
from osv import fields
from osv import osv
import pooler 
import tools
from tools.translate import _
from base_calendar import base_calendar
import logging

#
#  
#

class m2m_test(osv.osv):
    _name = "m2m.test"
    _description = "Many2Many Test"

    _columns = {
        'name' : fields.char('M2M Test',size=64,required=True,select="1"),
        'partner_id': fields.related('partner_id', select=True, type= 'many2many', relation='res.partner', string='Customer'),
    }

    _defaults = {
    }

    def create(self, cr, uid, values, context=None):
        if context is None:
            context = {}
        newid = values
        return newid

o2m_test()

m2m_test.xml

<?xml version="1.0"?>
<openerp>
<data>

    <menuitem name="Many2Many TEST" id="menu_m2m_test_main" parent="base.menu_config"/>

    <record model="ir.ui.view" id="view_m2m_test_form">
        <field name="name">m2m.test.form</field>
        <field name="model">m2m.test</field>
        <field name="type">form</field>
        <field name="arch" type="xml">
            <form string="Many 2 Many Test" version="7.0">
                <sheet>
                    <group>
                        <field name="name"/>
                    </group>
                    <group>
                        <field name="partner_id" widget="many2many">
                            <tree>
                                <field name="name"/>
                                <field name="fax"/>                                
                            </tree>
                        </field>
                    </group>
                </sheet>
            </form>
        </field>
    </record>

    <record model="ir.ui.view" id="view_m2m_test_tree">
        <field name="name">m2m.test.tree</field>
        <field name="model">m2m.test</field>
        <field name="type">form</field>
        <field name="arch" type="xml">
            <tree string="Many2 Many Test" >
                <field name="name"/>
            </tree>
        </field>
    </record>

    <record model="ir.actions.act_window" id="action_m2m_test_form">
        <field name="name">Many 2 Many Test</field>
        <field name="type">ir.actions.act_window</field>
        <field name="res_model">m2m.test</field>
        <field name="view_type">form</field>
        <field name="view_mode">tree,form</field>
        <field name="auto_refresh">20</field>
        <field name="help" type="html">
            <p class="oe_view_nocontent_create">
                Click to define a new Many2Many Test
            </p>
        </field>
    </record>

    <menuitem name="Many 2 Many Test" 
        id="menu_m2m_test_form" 
        parent="menu_m2m_test_main" 
        action="action_m2m_test_form"/>
</data>
</openerp>
0
Avatar
Buang
Avatar
AJ Schrafel Paper Corp
Penulis Jawaban Terbai

I figured it out:

You must have a bidirectional relationship between the two fields you want a M2M relationship with and the id1-id2 names are just place holders.

class o2m_test(osv.osv):
    _name = "o2m.test"
    _description = "One2Many Test"

    _columns = {
        'name' : fields.char('O2M Test',size=64,required=True,select="1"),
        'partner_ids': fields.many2many('res.partner', id1='category_id', id2='partner_id', string='Partners'),

    }

    _defaults = {
    }

o2m_test()

class res_partner(osv.osv):
    _inherit = "res.partner"
    _columns = {
        'fax_ids': fields.many2many('o2m.test', id1='partner_id', id2='category_id', string='Tags'),
    }

res_partner()
0
Avatar
Buang
Avatar
Dharmesh Rathod
Jawaban Terbai

Hi,

There is problem in 'related' field syntax.

'partner_id':fields.many2one('res.partner', 'Partner'),

'NEW_FIELD_NAME': fields.related('partner_id','MANY2MANY FIELD', type='many2many', relation='RELATED MODEL', string='LABEL'),

Email : info@acespritech.com
Skype : acespritech

1
Avatar
Buang
Menikmati diskusi? Jangan hanya membaca, ikuti!

Buat akun sekarang untuk menikmati fitur eksklufi dan agar terlibat dengan komunitas kami!

Daftar
Post Terkait Replies Tampilan Aktivitas
xml-rpc search on many2many query
v7 many2many
Avatar
Avatar
Avatar
2
Mar 15
10436
Multi step wizard with data from many2many relation?
v7 many2many
Avatar
0
Mar 15
7824
Error with non existing M2M field Diselesaikan
module many2many m2m
Avatar
1
Mei 21
3504
Problem adding new record to many2many relation for project model Diselesaikan
create many2many odoo10
Avatar
1
Mei 19
6622
.create() for a Many2many? Diselesaikan
create many2many odoo
Avatar
Avatar
2
Des 18
10052
Komunitas
  • Tutorial-tutorial
  • Dokumentasi
  • Forum
Open Source
  • Download
  • Github
  • Runbot
  • Terjemahan
Layanan
  • Odoo.sh Hosting
  • Bantuan
  • Peningkatan
  • Custom Development
  • Pendidikan
  • Temukan Akuntan
  • Temukan Mitra
  • Menjadi Partner
Tentang Kami
  • Perusahaan kami
  • Aset Merek
  • Hubungi kami
  • Tugas
  • Acara
  • Podcast
  • Blog
  • Pelanggan
  • Hukum • Privasi
  • Keamanan
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo adalah rangkaian aplikasi bisnis open source yang mencakup semua kebutuhan perusahaan Anda: CRM, eCommerce, akuntansi, inventaris, point of sale, manajemen project, dan seterusnya.

Mudah digunakan dan terintegrasi penuh pada saat yang sama adalah value proposition unik Odoo.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now