odoo中的ORM操作
ORM方法简介
OpenERP的关键组件, ORM是一个完整的对象关系映射层,是开发人员不必编写基本的SQL管道。
业务对象被声明继承字models.Models的python类。 这让业务对象在ORM层中神奇的持久化。
例子中的self.search方法,下面我们就来具体介绍一下orm的几种基本方法:
- 1. browse(ids)
- 作用:获取指定记录的对象。
- 参数:记录值的ids,
- 返回值:对象列表。
- browse方法应用的更多,因为v7版本的search等方法的返回值是ids,而v8版本中的返回值已经是目标对象的列表了,因此也就不需要再次调用browse方法。
- 例子:
- sale_order = self.env['sale.order'].browse(1) #获取数据库中id为1的销售订单。
- batch_line=batch_obj.browse(cr,uid,batch_id,context=None)
- 2. search(domain) 作用:搜索指定domain的记录集 参数:搜索domain [()]
- def on_batch_no_domain(self,cr,uid,ids,batch_name,mstate,context=None):
rvalue={}
rdomain={}
rdomain['dis_line_name']=[('id','in',[])]
rvalue['dis_line_name']=0
# batch_obj=self.pool.get('production.batch')
dis_line_obj=self.pool.get('dispatching.orders.line')
mrp_obj=self.pool.get('mrp.production')
if batch_name!=False and batch_name!='':
hr_emp_obj=self.pool.get('hr.employee')
hr_emp_search=hr_emp_obj.search(cr,uid,[('job_no','=',batch_name)],context=None)
batch_id=0
# batch_search=batch_obj.search(cr,uid,[('name','=',batch_name)],context=None)
dis_line_id=dis_line_obj.search(cr,uid,[('name','=',batch_name)],context=None)
if len(hr_emp_search)>0:
rvalue['lemployee']=hr_emp_search[0]
return {'value':rvalue}
if len(dis_line_id)==0:
raise osv.except_osv(u"提示!",u"未找到对应的批号或员工号!")- if len(dis_line_id)>0:
rvalue['dis_line_name']=dis_line_id[0]
elif len(batch_search)>0:
batch_id=batch_search[0]
if mstate!=False:
dis_domain=dis_line_obj.get_dis_line_domian(cr,uid,ids,batch_id,mstate,context=None)
if len(dis_domain)==1:
rvalue['dis_line_name']=dis_domain[0]
rdomain['dis_line_name']=[('id','in',dis_domain)]
else:
rdomain['dis_line_name']=[('id','in',dis_domain)]
batch_line=batch_obj.browse(cr,uid,batch_id,context=None)
mrp_into=mrp_obj.browse(cr,uid,batch_line.production_id.id,context=None)
rvalue['production_id']=batch_line.production_id.id
rvalue['product_id']=mrp_into.product_id.id
rvalue['routing_id']=mrp_into.routing_id.id
return {'value':rvalue,'domain':rdomain}
- 返回值:符合搜索结果的对象列表. 例子:
- product_obj=self.pool('product.product')
partner=self.pool('res.partner').browse(cr,uid,[vals.get('partner_id')],context).name
- students = self.search[('name','=',self.name)] 查找所有与当前对象名字相同的学员。
3.create(val)
作用:创建对象
参数:要创建的对象字典
返回值:新创建的对象
例子:
- student = self.create({
- 'name':'张三',
- 'age':26,
- 'sex':'m',
- 'sno':'0003',
- })
这样就创建了一个新的学员
4. write(val)
- #生成单子
def action_sale_create_man(self, cr, uid, ids, context=None):
assert len(ids)==1
sale= self.browse(cr,uid,ids[0],context=None)
today=time.strftime('%Y-%m-%d',time.localtime(time.time()))
productobj = self.pool.get('prod.prod')
manufactureobj=self.pool.get('manu.origin')
vals={}
record=[]
i=1
for zz_obj in sale.zzmx_id:
record.append((0,0,{'product_id':zzmx_obj.product_id.id,'sequence':i,'partner_id':zzmx_obj.partner_id.id,
'qty':zzmx_obj.qty,'price':zzmx_obj.price,'date_plan':sale.date,'date_zzao':sale.zddate,
'je':(zzmx_obj.qty*zzmx_obj.price)
}))
i+=1- vals={'sjdoc':sale.sjdoc,'product_id':zzmx_obj.product_id.id,'yuname':sale.id,'ywstyle':sale.ywstyle,'doctype_id':sale.doctype_id.id,'date_planned':today,'date_kdan':today,'partner_id':sale.partner_id.id,'zzjh_id':record,'state':'draft'}
llnew_id=manuobj.create(cr,uid,vals,context=context)
return True
作用:修改对象
参数:需要修改参数的字典
返回值:True or False
- def _picking_counts(self, cr, uid, ids, field_name, arg, context=None):
# fromkeys()方法用于创建一个新的字典
res = dict.fromkeys(ids, 0)
try:
name=self.browse(cr,uid,ids[0],context).name
pickobj=self.pool('stock.png')
searchids=pickobj.search(cr,uid,[('origin','ilike',name)])
res[ids[0]]=len(searchids)
except:
print u"err!"
finally:
return res
5.unlink()
作用:删除记录
- def add_za_order_line(self, cr, uid,man_id, record, context=None):
man_obj=self.pool.get('manufacture.origin')
id=man_id
vals={}
vals={'line_id':record}
print vals
self.write(cr,uid,[id],vals,context=context)
return True
例子:
- def unlink(self, cr, uid, ids, context=None):
sale_origins = self.read(cr, uid, ids, ['state'], context=context)
unlink_ids = []
for s in sale_origins:
if s['state'] in ['draft','cancel']:
unlink_ids.append(s['id'])
else:
raise osv.except_osv((u'警告!'),(u'不可删除'))- return osv.osv.unlink(self, cr, uid, unlink_ids, context=context)
对于v7版本 同样是以上的五种方法,只不过每种方法都需要添加cr,uid,ids,context等几个参数,v7方法本文不做过多介绍,需要的同学请看这里
env是环境变量,可以借助此变量获取odoo中的任一对象,举例来说,如果我想要获取销售订单对象,我就可以使用如下的写法:
- self.env['sale.order']
v8版本中是pool对象:
- self.pool.get('sale.order')
odoo中的lambda:
- _defaults={
'name': lambda obj, cr, uid, context: '/',
'user_id': lambda obj, cr, uid, context: uid,
}
odoo中的ORM操作的更多相关文章
- odoo 的一些orm 操作
1.基础文件及目录结构 在认识odoo ORM框架前,先介绍一下odoo中模块目录结构. data:存放模块预制数据 i18n:存放国际化文件 models:存放模型等py代码 securit ...
- 在pycharm中进行ORM操作
打开manage.py, 复制 import..... if.......os..... 导入django,开启django, 导入app中的models orm操作 import os if _ ...
- Odoo中的ORM API(模型数据增删改查)
转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/10826214.html 一:增 1:create():返回新创建的记录对象 self.create({'na ...
- Django中的ORM介绍,字段以及字段的参数。
Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...
- golang利用beego框架orm操作mysql
GO引入orm框架操作mysql 在beego框架中引入orm操作mysql需要进行的步骤: 第一步:导入orm框架依赖,导入mysql数据库的驱动依赖 import ( "github.c ...
- Django中的ORM进阶操作
Django中的ORM进阶操作 Django中是通过ORM来操作数据库的,通过ORM可以很easy的实现与数据库的交互.但是仍然有几种操作是非常绕也特别容易混淆的.于是,针对这一块,来一个分类总结吧. ...
- Django中的app及mysql数据库篇(ORM操作)
Django常见命令 在Django的使用过程中需要使用命令让Django进行一些操作,例如创建Django项目.启动Django程序.创建新的APP.数据库迁移等. 创建Django项目 一把我们都 ...
- django基础之day05,orm字段参数,自定义需要的字段,orm中的事务操作
orm字段和参数 charfield varchar integerfield int bigintegerfield bigint emailfield varchar(254) datefield ...
- Django中ORM操作
ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...
随机推荐
- 简单的TabLayout+Fragment选项卡
TabLayout属性: app:tabIndicatorColor="#fff" //下方滚动的下划线颜色 app:tabIndicatorHeight="10dp& ...
- Java集合之TreeMap源码分析
一.概述 TreeMap是基于红黑树实现的.由于TreeMap实现了java.util.sortMap接口,集合中的映射关系是具有一定顺序的,该映射根据其键的自然顺序进行排序或者根据创建映射时提供的C ...
- Log4J Appender - 将Log4J的日志内容发送到agent的source
项目中使用log4j打印的内容同时传输到flume 1.flume端 flume的agent配置内容如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 a1.sour ...
- 聊聊setTimeout和setInterval线程
在聊setTimeout和setInterval这两个事件的前,先聊另外一个与之密切关联的知识点,那就是线程(thread).而线程有常常跟另外一个词语--“进程”一起出现.那么何为线程?何为线程呢? ...
- MySQL——优化嵌套查询和分页查询
优化嵌套查询 嵌套查询(子查询)可以使用SELECT语句来创建一个单列的查询结果,然后把这个结果作为过滤条件用在另一个查询中.嵌套查询写起来简单,也容易理解.但是,有时候可以被更有效率的连接(JOIN ...
- Django之form总结
复习Django项目结构: 主要的文件:manage.py,url.py,views.py,settings.py,models.py manage.py:项目管理文件,一般不做修改. url.py: ...
- Pinyin4j实战
package com.haiyisoft.innovationcenter.pinyin; import org.junit.Test; import net.sourceforge.pinyin4 ...
- 进程管理-PV操作
1.临界资源:诸进程需要互斥方式对其进行共享的资源. 2.临界区:每个进程中访问临界资源的那段代码. 3.信号量:一种特殊的变量.
- aws linux主机root帐号登录
默认情况下,aws主机必须使用pem密码文件并且以ec2-user用户登录系统,之后很多操作都必须用sudo来以root权限执行操作,显得比较麻烦. 以下来自知乎的一个问答,亲测ok ## AWS E ...
- centos-7 虚拟机安装图形界面
centos-7 虚拟机安装图形界面 想到安装一个docker环境,于是拿出了以前装的虚拟机centos7,记得装完后,没进行任何配置(默认安装的是命令行界面). 配置网络 现有的虚拟机是没有办法联网 ...