Bỏ qua để đến Nội dung
Menu
Câu hỏi này đã bị gắn cờ
3 Trả lời
13486 Lượt xem

I'm trying to create a model named 'mantenimiento' based on project.task, but want to omit one or two columns from it.

I have this so far:

 _name = "project.mantenimientos" 
_description = "Mantenimientos"
_inherit = 'project.task'

How could I do it?

Thanks.

Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

You need to define those fields as function fields in your model to don't get created in your table.

Ảnh đại diện
Huỷ bỏ

Good trick. But in this case the field definition stays there in the model. And it might confuse tools that use the registry.

In this case it is prototype inheritance. A cleaner way would be if odoo allows specify the fields to exclude from the source model. Ex:

_inherit = {'project.task': {'exclude': ['fieldA', 'fieldB', ....]} }

Câu trả lời hay nhất

Hi Marie Pinto,

There are two possiblities to remove columns.

1) Easier way: Either inherit view and just invisible those columns which you don't want to show to user.

2) little tricky: override def init(self, cr): method of this model and execute query to drop columns by altering table as suggest by vivek.

  Risk factor in second step : If your are altering the table and removing any columns from table make sure those fields are not used in any views you have to remove it from there. if those fields are used in any base module view you have to replace it by inheriting views.

Hope this would clear more idea.

Regards,

Anil.




Ảnh đại diện
Huỷ bỏ
Câu trả lời hay nhất

There is not any way for delete columns using _inherit. You need to remove column from database(postgres) using alter table.

You need to execute query for drop column like : alter table project_mantenimientos drop column specific_column.

Ảnh đại diện
Huỷ bỏ
Bài viết liên quan Trả lời Lượt xem Hoạt động
2
thg 6 25
1457
2
thg 6 25
3667
0
thg 4 21
3863
1
thg 3 15
5955
1
thg 2 25
1690