关于Odoo12中基于视图创建的模型,ID取值的一些解决思路

对于基于视图创建的odoo模型,我们在创建数据库视图时需要给一个唯一性标识(ID)。
这个时候就需要确定ID怎么取值:

  1. 对于以某一个表作为主表查询结果创建为视图,或者可以找到一个唯一性标识的, 这种情况下,以主表的ID作为唯一标识即可。
CREATE OR REPLACE VIEW move_product AS
SELECT
	sm."id" AS "id",
	sm.location_id,
	sm.location_dest_id,
	pt."name",
	sm."state"
FROM
	stock_move sm,
	product_product pp,
	product_template pt
WHERE
	sm.product_id = pp."id"
AND pp.product_tmpl_id = pt."id"
AND sm."state" = 'done';

  1. 对于多表联查、分组查询等这种通过两个或多个字段联合起来作为唯一标识的,这种情况下就需要考虑如何拼凑或者引入ROW_NUMBER() OVER()来作为唯一标识了。
    2.1 对于ROW_NUMBER() OVER(),需要注意的是,随着数据的变化该ID会变化,如果以看到的ID去数据库中查当前的数据,很有可能查出来的数据不是想要的。所以对于这种情况,适合用于展示,或者选择之后,以多个字段联合去唯一查询或操作。
CREATE OR REPLACE VIEW move_product AS
SELECT
	ROW_NUMBER() OVER() AS "id",
	sm.location_id,
	sm.location_dest_id,
	pt."name",
	sm."state"
FROM
	stock_move sm,
	product_product pp,
	product_template pt
WHERE
	sm.product_id = pp."id"
AND pp.product_tmpl_id = pt."id"
AND sm."state" = 'done';

2.2 可以采用几个唯一标识拼凑为唯一标识的做法。这种做法的好处在于ID不会随数据变化而改变,弊端在于ID不能多,且数据量增长不能太多,否则很容易超出Interger的长度限制而报错。
这里先将ID转化为text然后拼接,注意的是这里将字符串截取为10位(超过11位很容易就超出Interger类型的长度而报错),然后再转为Interger(Odoo中ID用其他类型会报错)

CREATE OR REPLACE VIEW move_product AS
SELECT
	CAST(substr(CAST(sm."id" AS TEXT) || CAST(pp."id" AS TEXT), 0 , 10) AS INTEGER) AS "id",
	sm.location_id,
	sm.location_dest_id,
	pt."name",
	sm."state"
FROM
	stock_move sm,
	product_product pp,
	product_template pt
WHERE
	sm.product_id = pp."id"
AND pp.product_tmpl_id = pt."id"
AND sm."state" = 'done';
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值