odoo14-清理测试数据

该博客介绍了如何在Odoo中创建一个定时任务,用于删除销售订单、销售订单行、采购订单和采购订单行的数据。通过定义`del.data`模型并设置相关菜单,用户可以触发清理过程。清理操作由`del_data`方法执行,该方法使用SQL删除语句来清空指定表格。同时,博客还展示了XML配置以创建清理数据的用户界面和菜单项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

设置定时任务

from odoo import models, fields, api


class DelData(models.Model):

    _name = 'del.data'
    _description = '定时清理数据'

    @api.model
    def del_data(self):
        to_removes = [
            ['sale.order'],
            ['sale.order.line'],
            ['purchase.order'],
            ['purchase.order.line'],
        ]
        try:
            for line in to_removes:
                obj_name = line[0]
                obj = self.pool.get(obj_name)
                if obj:
                    sql = "delete from %s where id >= 1" % obj._table
                    self.env.cr.execute(sql)
                else:
                    print('无此模型')
        except Exception as e:
            raise Warning(e)
        return True

在这里插入图片描述

设置菜单

<?xml version="1.0" encoding="utf-8"?>
<odoo>
    <record id="view_del_data_transient" model="ir.ui.view">
        <field name="name">del.data.form</field>
        <field name="model">del.data</field>
        <field name="arch" type="xml">
            <form create="false" edit="false" delete="false">
                <p>确认清除数据吗?</p>
                <footer>
                    <button name="remove_data" string="确认" type="object" class="btn-primary" />
                    <button string="取消" class="btn-default" special="cancel" />
                </footer>
             </form>
         </field>
     </record>

    <record model="ir.actions.act_window" id="del_data_list_action">
        <field name="name">清除运行数据</field>
        <field name="res_model">del.data</field>
        <field name="view_type">form</field>
        <field name="view_mode">form</field>
        <field name="target">new</field>
        <field name="context">{'create': False}</field>
    </record>

    <menuitem action="del_data_list_action"
              id="menu_action_del_data_form"
              name="清除运行数据"
              parent="base.menu_users"/>
</odoo>

效果图
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值