Hi, I want to delete the records in the one2many fields when the original record that had them is deleted. I tried adding ondelete="cascade" to the one2many declaration but the records in the one2many table still remains when i delete the record holding it. How do i achieve this?
Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:
- CRM
- e-Commerce
- Kế toán
- Tồn kho
- PoS
- Project
- MRP
Câu hỏi này đã bị gắn cờ
1
Trả lời
32670
Lượt xem
Hi,
You should put ondelete="cascade"
in the field relation id like here:
class sale_order(osv.osv):
_name = 'sale.order'
_columns = {
'name': fields.char('Order Reference', size=64, required=True, readonly=True, states={'draft': [('readonly', False)], 'sent': [('readonly', False)]}, select=True),
'order_line': fields.one2many('sale.order.line', 'order_id', 'Order Lines', readonly=True, states={'draft': [('readonly', False)], 'sent': [('readonly', False)]}),
....
sale_order()
class sale_order_line(osv.osv):
_name = 'sale.order.line'
_columns = {
'order_id': fields.many2one('sale.order', 'Order Reference', required=True, ondelete='cascade', select=True, readonly=True, states={'draft':[('readonly',False)]}),
.
.
.
sale_order_line()
Thanks, i was doing it the other way round. Now it solved the problem
Bạn có hứng thú với cuộc thảo luận không? Đừng chỉ đọc, hãy tham gia nhé!
Tạo tài khoản ngay hôm nay để tận hưởng các tính năng độc đáo và tham gia cộng đồng tuyệt vời của chúng tôi!
Đăng kýBài viết liên quan | Trả lời | Lượt xem | Hoạt động | |
---|---|---|---|---|
|
0
thg 3 15
|
3243 | ||
|
2
thg 5 24
|
9193 | ||
Confirm on delete one2many line
Đã xử lý
|
|
5
thg 7 20
|
10695 | |
How to delete Confirmed Salary Slip?
Đã xử lý
|
|
5
thg 1 24
|
17097 | |
|
0
thg 9 15
|
3879 |