关于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';

猜你喜欢

转载自blog.csdn.net/sinat_23931991/article/details/103356531