Siirry sisältöön
Odoo Menu
  • Kirjaudu sisään
  • Kokeile ilmaiseksi
  • Sovellukset
    Talous
    • Kirjanpito
    • Laskutus
    • Kulut
    • Datataulukot (BI)
    • Asiakirjat
    • Allekirjoita
    Myynti
    • CRM
    • Myynti
    • Kassajärjestelmä myymälään
    • Kassajärjestelmä ravintolaan
    • Tilaukset
    • Vuokraus
    Verkkosivut
    • Verkkosivun Rakennustyökalu
    • Verkkokauppa
    • Blogi
    • Foorumi
    • Livechat
    • Verkko-oppiminen
    Toimitusketju
    • Varastointi
    • Tuotanto
    • Tuotteen elinkaaren hallinta (PLM)
    • Ostot
    • Huolto
    • Laatu
    Henkilöstöhallinto
    • Työntekijät
    • Rekrytointi
    • Vapaat
    • Arvioinnit
    • Suositukset
    • Kuljetuskalusto
    Markkinointi
    • Somemarkkinointi
    • Sähköpostimarkkinointi
    • Tekstiviestimarkkinointi
    • Tapahtumat
    • Markkinoinnin automaatio
    • Kyselyt
    Palvelut
    • Projekti
    • Työaikakirjaukset
    • Kenttähuolto
    • Asiakaspalvelu
    • Suunnittelu
    • Ajanvaraukset
    Tuottavuus
    • Viestintä
    • Hyväksynnät
    • IoT
    • IP-puhe
    • Tietokirjasto
    • WhatsApp
    Kolmannen osapuolen sovellukset Odoo-Studio Odoo-Pilvialusta
  • Toimialat
    Vähittäiskauppa
    • Kirjakauppa
    • Vaatekauppa
    • Huonekaluliike
    • Ruokakauppa
    • Laitteistokauppa
    • Lelukauppa
    Ruoka & Majoitus
    • Baari ja Pubi
    • Ravintola
    • Pikaruoka
    • Majatalo
    • Juomien jakelija
    • Hotelli
    Kiinteistöt
    • Kiinteistönvälitystoimisto
    • Arkkitehtitoimisto
    • Rakentaminen
    • Kiinteistönhallinta
    • Puutarhanhoito
    • Kiinteistön omistajien yhdistys
    Konsultointi
    • Tilitoimisto
    • Odoo-kumppani
    • Markkinointitoimisto
    • Lakitoimisto
    • Osaajahankinta
    • Tilintarkastus & sertifiointi
    Tuotanto
    • Tekstiili
    • Metalli
    • Huonekalut
    • Ruoka
    • Panimo
    • Yrityslahjat
    Terveys & Liikunta
    • Urheiluseura
    • Silmälasiliike
    • Kuntokeskus
    • Hyvinvointialan ammattilaiset
    • Apteekki
    • Kampaamo
    Kaupat
    • Yleismies
    • IT-laitteisto & Tuki
    • Aurinkoenergiajärjestelmät
    • Suutari
    • Siivouspalvelut
    • LVI-palvelut
    Muut
    • Voittoa tavoittelematon järjestö
    • Ympäristötoimisto
    • Mainostaulujen vuokraus  
    • Valokuvaus
    • Leasing-pyörät
    • Ohjelmistojen jälleenmyyjä
    Selaa kaikkia toimialoja
  • Yhteisö
    Opi
    • Kurssit
    • Dokumentaatio
    • Todistukset
    • Koulutus
    • Blogi
    • Podcast
    Kannusta kouluttautumaan
    • Koulutusohjelmat
    • Scale Up! Liiketoimintapeli
    • Vieraile Odoolla
    Hanki ohjelmisto
    • Lataa
    • Vertaile versioita
    • Julkaisut
    Tee yhteistyötä
    • Github
    • Foorumi
    • Tapahtumat
    • Käännökset
    • Ryhdy kumppaniksi
    • Kumppanipalvelut
    • Rekisteröi tilitoimistosi
    Hanki palveluja
    • Löydä kumppani
    • Löydä kirjanpitäjä
    • Varaa asiantuntijatapaaminen
    • Implementaatiopalvelut
    • Asiakasreferenssit
    • Tuki
    • Versionkorotukset
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Varaa demo
  • Hinnoittelu
  • Asiakaspalvelu

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

  • CRM
  • e-Commerce
  • Kirjanpito
  • Varastointi
  • PoS
  • Projekti
  • MRP
All apps
Sinun on rekisteröidyttävä, jotta voit olla vuorovaikutuksessa yhteisön kanssa.
Kaikki kirjoitukset Ihmiset Merkit
Tunnisteet (Näytä kaikki)
odoo accounting v14 pos v15
Tietoa tästä foorumista
Sinun on rekisteröidyttävä, jotta voit olla vuorovaikutuksessa yhteisön kanssa.
Kaikki kirjoitukset Ihmiset Merkit
Tunnisteet (Näytä kaikki)
odoo accounting v14 pos v15
Tietoa tästä foorumista
Apua

How to insert value to a one2many field in table with create method?

Tilaa

Saat ilmoituksen, kun tähän viestiin ilmaantuu aktiviteettia

Tämä kysymys on merkitty
python
5 Vastaukset
232017 Näkymät
Avatar
Gopakumar N G

I have created two wizards which are shown below:

from osv import fields, osv
class fee_structure(osv.osv_memory):
_name="fee.structure"
_description="Fee Structure"
_columns={
            'name': fields.char('Title', size=64),
            'area_id': fields.many2one('department.area', 'Area'),
            'grade_id': fields.many2one('department.grade', 'Grade'),
            'fee_template_ids': fields.many2many('department.fee_template', 'fee_structure_template_rel', 'fee_structure_id', 'dept_fee_template_id', 'Templates'),
            'fee_ids': fields.one2many('wizard.fee', 'fee_structure_id','Extra Fee'),
          }

def button_create(self, cr, uid, ids, context={}):
    print '..................button_create................'
    wizard_obj=self.browse(cr, uid, ids, context=context)[0]
    template_ids=[]
    for template_id in wizard_obj.fee_template_ids:
        template_ids.append(template_id.id)
self.pool.get('institution.fee').create(cr, uid, {
                                'name': wizard_obj.name,
                                 'active': True,
                                  'area_id': wizard_obj.area_id.id,
                                   'grade_id': wizard_obj.grade_id.id,
                                   'fee_template_ids': [(6,0,template_ids)],
                                #  needs to add values for field fee_ids here,
                                                      })
fee_structure()

class wizard_fee(osv.osv_memory):
_name="wizard.fee"
_description="Fee Wizard"
_columns={
            'fee_id': fields.many2one('fee.fee', 'Fee'),
            'amount': fields.float('Amount'),
            'fee_structure_id': fields.many2one('fee.structure',  'Fee Structure'),
          }

wizard_fee()

The model institution.fee is

class institution_fee(osv.osv):
_name="institution.fee"
_description="Institution Fee"
_columns={
            'name': fields.char('Fee Name', size=64),
            'active': fields.boolean('Active'),
            'area_id': fields.many2one('department.area', 'Area'),
            'grade_id': fields.many2one('department.grade', 'Grade'),
            'fee_template_ids': fields.many2many('department.fee_template', 'institution_fee_template_rel', 'inst_fee_id', 'dept_fee_template_id', 'Fee Template'),
            'fee_ids': fields.one2many('department.fee_structure', 'inst_fee_id', 'Extra Fee'),
          }
_defaults={
            'active': True
           }
institution_fee()

I have added the values of the many2one field fee_template_ids to model institution.fee , similarly I want to add the values to the one2many field fee_ids using wizard.fee to institution.fee .

The fee.structure wizard is called from a menuitem and its use is to create a fee structure(institution.fee model).

12
Avatar
Hylkää
Avatar
nazarii
Paras vastaus

This may help you:

(0, 0,  { values })    link to a new record that needs to be created with the given values dictionary
(1, ID, { values })    update the linked record with id = ID (write *values* on it)
(2, ID)                remove and delete the linked record with id = ID (calls unlink on ID, that will delete the object completely, and the link to it as well)
(3, ID)                cut the link to the linked record with id = ID (delete the relationship between the two objects but does not delete the target object itself)
(4, ID)                link to existing record with id = ID (adds a relationship)
(5)                    unlink all (like using (3,ID) for all linked records)
(6, 0, [IDs])          replace the list of linked IDs (like using (5) then (4,ID) for each ID in the list of IDs)

In your case you need to use (0, 0, { values })

58
Avatar
Hylkää
Gopakumar N G
Tekijä

Thanks nazarii..

Carlos Llamacho

The only option that takes a list is number 6, right? I cannot do a (4, [id, id, ids]) and have it all been related with my record? Or a (0, 0, [{values}])?

nazarii

If you want to link new record to existing wizards than yes, you need to use (6, 0, [IDS]). But if you want to create new wizards on the fly and link to this record than use 'fee_ids': [(0, 0, values1), (0, 0, values2) ]

iWesabe Technologies

Great

J. Blanco Caura

Thanks

Avatar
Kirubanidhi Rajarathinam
Paras vastaus

Insert a new record in one2many fields in odoo9.

Code:

@api.multi

def Create_One2many_method(self):

search_var = self.search([('staff_age','=',0)])

search_var.write({

                    'stud_ids': [(0,0, {

                                                'reg_no':4200,

                                                 'stud_email':'anbulove@gmail.com',

                                                   'stud_phone':'9788987689',

 

})]

})

 

7
Avatar
Hylkää
Avatar
Sandip Chavda
Paras vastaus

Odoo 15 and Odoo 16:

Command.create(vals) | (0, 0, { values }) link to a new record that needs to be created with the given values dictionary
Command.update(ID, vals) | (1, ID, { values }) update the linked record with id = ID (write *values* on it)
Command.delete(ID) | (2, ID) remove and delete the linked record with id = ID (calls unlink on ID, that will delete the object completely, and the link to it as well)
Command.unlink(ID) | (3, ID) cut the link to the linked record with id = ID (delete the relationship between the two objects but does not delete the target object itself)
Command.link(ID) | (4, ID) link to existing record with id = ID (adds a relationship)
Command.clear() | (5) unlink all (like using (3,ID) for all linked records)
Command.set([IDs]) | (6, 0, [IDs]) replace the list of linked IDs (like using (5) then (4,ID) for each ID in the list of IDs)

4
Avatar
Hylkää
Odoo

check spamming

Avatar
Annie Marinna
Paras vastaus

In my case, the wizard should add or relate one or more existing records into the "one2many" field of the new record. Then if I'm not wrong, what I must to do is a (1, ID, { values }) with ID = the id of the fresh new record, right?

0
Avatar
Hylkää
Annie Marinna

but this is what I get :( AttributeError: "'list' object has no attribute 'copy'"

Avatar
Abdelhalim KADDOUR GUETTAOUI
Paras vastaus

i want to explain how odoo framework create related table for many2many for exemple we have your model1 where you created "category_id" and the other model2 where you Create the relation with many2many

Now for each models odoo create table in Psql , so for models1 odoo create in Psql table:model1and for the second model Psql create table: Model2 and for the relation many2many Psql create the third his name is table:model1_Model2

so in odoo create this table with underscore and the 2 table Name

0
Avatar
Hylkää
Nautitko keskustelusta? Älä vain lue, vaan osallistu!

Luo tili jo tänään nauttiaksesi yksinoikeusominaisuuksista ja osallistuaksesi mahtavaan yhteisöömme!

Rekisteröidy
Aiheeseen liittyviä artikkeleita Vastaukset Näkymät Toimenpide
new python env
python
Avatar
0
maalisk. 25
2322
What means "Too many values to unpack" message? Ratkaistu
python
Avatar
Avatar
Avatar
Avatar
Avatar
4
huhtik. 24
175781
have no data in screen. read data in my own module from different model
python
Avatar
0
jouluk. 23
2941
how to disable add product in sales of odoo 12
python
Avatar
Avatar
1
jouluk. 22
4127
Product moves
python
Avatar
Avatar
Avatar
2
marrask. 22
3914
Yhteisö
  • Kurssit
  • Dokumentaatio
  • Foorumi
Avoin lähdekoodi
  • Lataa
  • Github
  • Runbot
  • Käännökset
Palvelut
  • Odoo.sh hosting
  • Tuki
  • Versionkorotus
  • Räätälöidyt kehitykset
  • Koulutus
  • Löydä kirjanpitäjä
  • Löydä kumppani
  • Ryhdy kumppaniksi
Meistä
  • Yrityksemme
  • Tavaramerkki
  • Ota yhteyttä
  • Työpaikat
  • Tapahtumat
  • Podcast
  • Blogi
  • Asiakkaat
  • Oikeudellinen ilmoitus • Yksityisyys
  • Tietoturva
الْعَرَبيّة 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 on kokoelma avoimen lähdekoodin yrityssovelluksia, jotka kattavat kaikki yrityksesi tarpeet: asiakkuudenhallinta eli CRM, verkkokauppa, kirjanpito, varastointi, kassajärjestelmä, projektinhallinta, jne.

Odoon uniikki arvolupaus on olla samanaikaisesti erittäin helppokäyttöinen ja täysin integroitu.

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