Odoo 中的关系?

问题描述 投票:0回答:1

我正在尝试制作一个 Odoo 模块来测试 CRUD 功能,我正在尝试使用我已经创建的 2 个 PostGreSQL 表之间的关系,首先,我使用一个视图来使 Odoo 与数据库联系,但是它只能读取数据,不能删除、创建或更新,所以我决定改为使用真实的表,但我无法使其工作,这是我所拥有的:

from odoo import models, fields

class PcClientes(models.Model):
    _name = 'clientes.pc_clientes'
    _description = 'Clientes PC'
    _table = 'pc_clientes'  # Nombre de la tabla en la base de datos
    _auto = False  # No queremos que Odoo cree la tabla automáticamente, ya existe

    # Campos de la tabla pc_clientes
    xempgen_id = fields.Char(string='EmpGen ID', required=True)
    xcliente_id = fields.Char(string='Cliente ID', required=True)
    xcod_postal = fields.Char(string='Código Postal')
    xdomicilio = fields.Char(string='Domicilio')
    xnif = fields.Char(string='NIF')
    xnif_ue = fields.Char(string='NIF UE')
    xnomabrev = fields.Char(string='Nombre Abreviado')
    xnombre = fields.Char(string='Nombre', required=True)
    xpais_id = fields.Char(string='ID País')
    xper_fiscal = fields.Char(string='Período Fiscal')
    xpoblacion = fields.Char(string='Población')
    xprovincia_id = fields.Char(string='ID Provincia')
    xlatitud = fields.Float(string='Latitud')
    xlongitud = fields.Float(string='Longitud')
    trial723 = fields.Char(string='Trial723')

    # Relación con la tabla pl_clientes
    pl_cliente_id = fields.Many2one(
        'clientes.pl_clientes', 
        string="PL Cliente", 
        ondelete='cascade', 
        required=True
    )

class PlClientes(models.Model):
    _name = 'clientes.pl_clientes'
    _description = 'Clientes PL'
    _table = 'pl_clientes'  # Nombre de la tabla en la base de datos
    _auto = False  # No queremos que Odoo cree la tabla automáticamente, ya existe

    # Campos de la tabla pl_clientes
    xcliente_id = fields.Char(string='Cliente ID', required=True)
    xcod_docto = fields.Char(string='Código Documento')
    xcopias_alb = fields.Integer(string='Copias Albarán')
    xcopias_fact = fields.Integer(string='Copias Factura')
    xmodalidad_id = fields.Char(string='ID Modalidad')
    xpor_comision = fields.Float(string='Porcentaje Comisión')
    xreferencia = fields.Char(string='Referencia')
    xrepresentante_id = fields.Char(string='ID Representante')
    xsecpref_id = fields.Char(string='ID SecPref')
    xtipo_fact = fields.Integer(string='Tipo de Factura', required=True)
    xempgen_id = fields.Char(string='EmpGen ID', required=True)
    xempresa_id = fields.Char(string='Empresa ID', required=True)
    xfax = fields.Char(string='Fax')
    xtelefono = fields.Char(string='Teléfono')
    xemail = fields.Char(string='Email')
    xfecha_alta = fields.Datetime(string='Fecha Alta')
    xfecha_baja = fields.Datetime(string='Fecha Baja')
    xinternet = fields.Char(string='Internet')
    xlangage = fields.Integer(string='Lenguaje')
    xlangage_remplace = fields.Integer(string='Lenguaje Reemplazado')
    xcopias_ped = fields.Integer(string='Copias Pedido')
    xcredito = fields.Float(string='Crédito')
    xctacon = fields.Char(string='Cta Con')
    xctamayor = fields.Char(string='Cta Mayor')
    xcyc_activo = fields.Integer(string='Cyc Activo')
    xcyc_poliza = fields.Char(string='Cyc Póliza')
    xdivisa_id = fields.Char(string='ID Divisa')
    xdto_com = fields.Float(string='Dto. Comercial')
    xcoment_albaran = fields.Char(string='Comentario Albarán')
    xcoment_factura = fields.Char(string='Comentario Factura')
    xcoment_pedido = fields.Char(string='Comentario Pedido')
    xcontacto = fields.Char(string='Contacto')
    xagrupa_alb = fields.Integer(string='Agrupa Albarán')
    xalb_valorado = fields.Integer(string='Albarán Valorador')
    xalta_modif = fields.Integer(string='Alta Modificada')
    xcalificacion_id = fields.Char(string='ID Calificación')
    xcargo = fields.Char(string='Cargo')
    xrecibe_facturae = fields.Integer(string='Recibe Facturae')
    xxjuego_id = fields.Char(string='ID Juego')
    p856_tipo_tarifa = fields.Char(string='Tipo Tarifa')
    p856_dto_metraje = fields.Float(string='Dto. Metraje')
    p856_dto_tarifa = fields.Float(string='Dto. Tarifa')
    p856_agen_com_id = fields.Char(string='Agente Com')
    p856_eti_metr_ext = fields.Char(string='Etiqueta Metr Ext')
    p856_observaciones = fields.Char(string='Observaciones')
    p856_cadena = fields.Char(string='Cadena')
    p856_credito_aseg = fields.Float(string='Crédito Asegurado')
    p856_credito_rioma = fields.Float(string='Crédito Rioma')
    p856_crm_id = fields.Char(string='ID CRM')
    p856_modificado = fields.Integer(string='Modificado')
    p856_modificado_r = fields.Integer(string='Modificado R')
    p856_dto_met_max = fields.Float(string='Dto. Metraje Max')
    p856_dto_pie_max = fields.Float(string='Dto. Pie Max')
    p856_entite = fields.Char(string='Entidad')
    p856_pass_crm = fields.Char(string='Pass CRM')
    p856_cerrado = fields.Integer(string='Cerrado')
    p856_supervisor = fields.Char(string='Supervisor')
    p856_tipo_cliente = fields.Integer(string='Tipo Cliente')
    p856_fact_ftp = fields.Integer(string='Fact. FTP')
    p856_backoffice_id = fields.Char(string='ID Backoffice')
    trial726 = fields.Char(string='Trial 726')

    # Relación con la tabla pc_clientes
    pc_cliente_id = fields.Many2one(
        'clientes.pc_clientes', 
        string="PC Cliente", 
        ondelete='cascade', 
        required=True
    )

这是我的模型.py

    <odoo>
    <data>

      <record id="clientes_list_view" model="ir.ui.view">
        <field name="name">clientes.list.view</field>
        <field name="model">clientes.pc_clientes</field>
        <field name="arch" type="xml">
          <list>
            <field name="xempgen_id"/>
            <field name="xcliente_id"/>
            <field name="xnomabrev"/>
            <field name="xnombre"/>
            <field name="pl_cliente_id.xfax"/>
          </list>
        </field>
      </record>

      <record id="clientes_form_view" model="ir.ui.view">
        <field name="name">clientes.form.view</field>
        <field name="model">clientes.pc_clientes</field>
        <field name="arch" type="xml">
          <form>
          <group name="Datos indicativos" string="Datos indicativos" class="central">

            <group>
              <field name="xnombre" class="field"/>
            </group>
            <group>
              <field name="xnomabrev" class="field"/>
            </group>
            <group>
              <field name="xreferencia" class="field"/>
            </group>
              <field name="pl_cliente_id.xfax" class="field"/>
            <group/>

            

          </group>
          </form>
        </field>
      </record>

      <record id="clientes_action" model="ir.actions.act_window">
        <field name="name">Clientes</field>
        <field name="res_model">clientes.pc_clientes</field>
        <field name="view_mode">list,form</field>
      </record>

      <menuitem id="menu_root" name="Rioma"/>
      <menuitem id="menu_clientes" name="Clientes" parent="menu_root"/>
      <menuitem id="menu_clientes_list" name="Clientes List"
      parent="menu_clientes" action="clientes_action"/>
      
    </data>
</odoo>

这是我的观点。

当我运行 odoo 服务器时,它给了我这个错误:

Error while validating view near:

            <field name="xnombre"/>
            <field name="pl_cliente_id.xfax"/>
          </list>
Field "pl_cliente_id.xfax" does not exist in model "clientes.pc_clientes"

View error context:
{'file': 'c:\\odoo\\modules\\clientes\\views\\templates.xml',
 'line': 7,
 'name': 'clientes.list.view',
 'view': ir.ui.view(878,),
 'view.model': 'clientes.pc_clientes',
 'view.parent': ir.ui.view(),
 'xmlid': 'clientes_list_view'}

我是 Odoo 的新人,非常感谢你们的帮助

python odoo odoo-8 odoo-10 odoo-9
1个回答
0
投票

创建新模型时,还必须创建安全访问规则 通常每个模块上都有一个安全文件夹,其中包含文件 security.xmlir.model.access.csv

关于您的错误,列表模型末尾的关系字段没有意义,因为它正在创建与其自身的关系。也许您复制粘贴了以前的模型而忘记删除这部分?

© www.soinside.com 2019 - 2024. All rights reserved.