利用ir.sequence自动生成序列号

利用ir.sequence自动生成序列号

什么是序列号

可以这么理解,我有一个产品序号,编码的前缀是SOP,后缀是0001~9999的序号,没生成一个产品就自动流水加一,序列号不会重复,odoo中的ir.sequence这个模型提供了这个方法。

建立序号规则对象

建立一个XML,并记得在__mainfest__.py中导入

<?xml version="1.0" encoding="utf-8"?>
<odoo>
    <data noupdate="1">
        <!-- Sequences for sale.order -->
        <record id="my_sale_sequence" model="ir.sequence">
            <field name="name">Sales Order</field>
            <field name="code">my_sale.sale_order</field>
            <field name="prefix">SO</field>
            <field name="padding">3</field>
            <field name="company_id" eval="False"/>
        </record>

    </data>
</odoo>

name?序列规则得名称,可自定义
code 序列规则得编码,要求最好唯一,使用模块.表名来命确保唯一
prefix 序号编码的前缀
padding 填充数据的位数

创建数据时自动获取序号

@api.model
    def create(self, vals):
        vals['name'] = self.env['ir.sequence'].next_by_code('wf_sale.sale_order')
        return super(SaleOrder,self).create(vals)

原文地址:https://www.cnblogs.com/Kingfan1993/p/10784035.html

时间: 2024-10-07 22:30:45

利用ir.sequence自动生成序列号的相关文章

oracle中利用trigger,sequence自动生成ID

http://zhanghong.iteye.com/blog/865937 1. 首先创建数据库表 SQL> create table customer( 2  id number(8) not null primary key, 3  name varchar2(20), 4  age number(3), 5  gender varchar2(8) 6  ); 2. 创建Sequence: create sequence customer_SEQUENCE start with 6 inc

利用&quot;SQL&quot;语句自动生成序号的两种方式

1.首先,我们来介绍第一种方式: ◆查询的SQL语句如下: select row_number() over (order by name) as rowid, sysobjects.[name] from sysobjects ◆运行的结果: rowid   name 1           all_columns 2           all_objects 3           all_parameters 4           all_sql_modules 5          

利用LP Wizard自动生成元器件

1.       工具说明 Win7.LP Wizard 10.3.2.cadence16.3 2.       生成DDR2封装步骤 首先在网络上查找Micron Technology公司的MT47H系列DDR2的datasheet文档,下图显示的是大小为1Gb:x16的84-Ball FBGA封装.文档中对封装尺寸进行了详细的说明. 打开LP Wizard 10.3.2,点击Calculate菜单,选中下拉菜单中的SMD Calculator,弹出元器件封装选择界面. 注:下图为元器件封装选

在条码标签打印软件上绘制条形码并自动生成序列号

在做条码标签的时候,输入序列号很简单,如果只有五六个,手工输入就可以的,可是如果有100个,1000个,甚至10000个序列号的时候,我们该怎么办呢?今天就来分享下在条码标签打印软件上制作条形码序列号的方法,具体操作步骤如下:1.打开条码标签打印软件,新建纸张,在文档设置里面设置需要的纸张,这里咱们以A4纸为列,设置下标签的行数和列数以及标签尺寸,这个都是根据自己的要求设计的2.在我们新建的纸张上,点击左侧绘制一维条码按钮,在画布上绘制一个条形码,右击属性,出来一个图形属性对话框,在数据源里,点

利用MyBatis生成器自动生成实体类、DAO接口和Mapping映射文件

1. mybatis-generator-core-1.3.5.jar 下载地址:https://github.com/mybatis/generator/releases 2. msyql-connector-java-5.1.30.jar 网上下载. 3. 配置generatorConfig.xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration P

局域网内利用gitlab,jenkins自动生成gitbook并发布(nginx)

安装了GitBook,内网使用,没法用上gitbook的网页. 用gitbook serve只能展示一本书,而且也不利于长期维护. 于是使用gitlab,jenkins,和nginx配合gitbook使用. 基本的流程是这样的,每本书作为项目托管到gitlab上,每次提交,gitlab会触发jenkins,jenkins会把仓库的内容拉下来,gitbook build 并复制到Web server(Nginx)的目录下,并加上可读权限,然后局域网内的人就都可以直接访问了. 下面记录过程 首先机器

【mybatis源码学习】利用maven插件自动生成mybatis代码

[一]在要生成代码的项目模块的pom.xml文件中添加maven插件 <!--mybatis代码生成器--> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <dependencies>

Eclipse中利用JPA Tools自动生成带注解的实体类

一. 二. 三. 四. 五. 六. 七. 八. 九. 十一.上一步点击OK按钮以后,回到填写数据库连接信息页面,如下图,填写连接信息. 十二.测试是否可以Ping通连接 十三. 十四.新建一个普通的java工程,比如generator-entity(实体类生成在该工程中) 十五.右击该工程,打开属性,选择Project Facets选项,选中JPA复选框,此时Apply and Close按钮还是灰色的,无法点击. 十六.配置 十七. 十八. 十九. 二十.工程目录变为如下图: 二十一. 二十二

MyBatis代码自动生成(利用命令)

这几天在学习springmvc,需要用到mybatis,所以研究了一下mybatis自动代码生成,当然也可以手动敲,但是那样效率非常的慢,并且出错率也是很高的,利用MyBatis生成器自动生成实体类.DAO接口和Mapping映射文件.这样可以大大节约开发时间,将生成的代码copy到项目工程中即可. 要想实现代码的自动生成,首先要下载一个工具:http://download.csdn.net/detail/u010608551/9434523,下载后解压zip文件,解压后的目录应该是如下的效果: