OPENERP 库存管理源码分析(Property Fields 个人理解)
-
声明一个属性 / Declaring a propertyfields.property 是一个属性 它是一个特殊的字段 / A property is a special field: fields.property.这之后你需要在XML文件为属性建立一个默认值 / Then you have to create the default value in a .XML file for this property:
这个方式不是像设置一个普通的默认值 例如给个NAME字段设置个 PO什么的 而且在 外键上设置一个默认值 而这个默认值是外键对应的表的一行的ID 的值[[i] 本帖最后由 leetaizhu 于 2010-3-12 13:29 编辑 [/i]]
-
解释的非常的清晰,最后两个图说明了如何在Open ERP系统内设置默认的属性(Property)。其实我们也可以在XML文件中定义这个默认熟悉,比如你举的这个例子所对应的默认属性的XML文件是stock_data.xml:
[code] <record forcecreate="True" id="property_stock_supplier" model="ir.property">
<field name="name">property_stock_supplier</field>
<field name="fields_id" search="[('model','=','res.partner'),('name','=','property_stock_supplier')]"/>
<field eval="'stock.location,'+str(stock_location_suppliers)" name="value"/>
</record>
<record forcecreate="True" id="property_stock_customer" model="ir.property">
<field name="name">property_stock_customer</field>
<field name="fields_id" search="[('model','=','res.partner'),('name','=','property_stock_customer')]"/>
<field eval="'stock.location,'+str(stock_location_customers)" name="value"/>
</record>
[/code]
model=ir.property表示以下的记录内容是属于“ir.property“对象的一个资源(或者说是ir_property数据库表中的一条记录),它记录了两个字段内容:field_id 和 value。field_id中的内容根据search的条件结合你第一张图中的信息可以了解,其应该是‘Customer Location‘或 ‘Supplier Location', 在数据库中实际上记录的是这个字段在ir_model_fields表中对应的id值。
而value中的内容是什么呢?我们首先要了解stock_location_customers 或 stock_location_suppliers在这里表示的是什么,其实这两个名称是指在当前XML文件中的record节点的id:
[code] <record id="stock_location_suppliers" model="stock.location">
<field name="name">Suppliers</field>
<field name="location_id" ref="stock_location_locations_partner"/>
<field name="usage">supplier</field>
</record>
<record id="stock_location_customers" model="stock.location">
<field name="name">Customers</field>
<field name="location_id" ref="stock_location_locations_partner"/>
<field name="usage">customer</field>
</record>
[/code]
也就是对应了stock_location数据库表中的一条记录。eval=... 表示将字符串作为Python表达式处理,处理的结果就是把两个字段连接起来。在数据库中stock_location_customers和stock_location_suppliers代表的是其在stock_location表中的id值,value值保存在数据库里就类似:'stock.location, 7' 这样,其结果就反映在你贴出的最后两张图中