odoo数据库 导入、导出

首先odoo框架下postgresql数据库中,表结构的存储方式:

存在id(小写),并没有所谓的外部ID

例如数据库中的国家表:模块名_tb_country   (注意:odoo框架下,数据库中生成的表命名规则是,模块名_实际表名)

id   code  name

1   001   中国

2   002   美国

3   003   德国

。。。

odoo系统自带功能,前台界面导出的时候:导入兼容导出模式

这种情况下导出的csv表数据结构 :  注意这里导出的id为小写

id                                                      code        name

__export__.模块名_tb_country_1        001          中国

__export__.模块名_tb_country_2        002          美国

__export__.模块名_tb_country_3        003          德国

我们再对比看下 另一种导出模式:导出全部数据

这种情况下导出的csv数据结构 :如果选择导出id,那么导出的CSV表中,外部id字段的表头,会和ID做个区分,改成了External ID

External ID                                      ID      code        name

__export__.模块名_tb_country_1       1         001          中国

__export__.模块名_tb_country_2       2         002          美国

__export__.模块名_tb_country_3       3         003          德国

我们可以看到 两种方式导出的.CSV表结构可能有些区别,那么我们如果从外部导入原始数据的时候,应该怎么导入呢,官方建议是按照odoo的机制,最好导入外部id;

可以参考文档:

https://www.odoo.com/documentation/user/11.0/general/base_import/import_faq.html

http://www.sunpop.cn/documentation/user/10.0/zh_CN/general/base_import/import_faq.html

那我们导入数据的时候,具体应该按照哪种格式,制作CSV源表,

建议:比如我们在一个新odoo环境下,要导入国家表,那么可以按照如下格式:

方式1:

ID                                    code        name

模块名_tb_country_1           001          中国

模块名_tb_country_2           002          美国

模块名_tb_country_3           003          德国

方式2:

ID                                                        code        name

__export__.模块名_tb_country_1           001          中国

__export__.模块名_tb_country_2           002          美国

__export__.模块名_tb_country_3           003          德国

方式3:

ID                                        code        name

tb_country_1           001          中国

tb_country_2           002          美国

tb_country_3           003          德国

两种方式都可以,方式1, 2加了__export__.前缀,系统也是正常识别的,不会报错,只是ID不会从1开始。(注:这里写错了 ,其实ID 不从1开始,是因为导入数据的时候,不能点击验证,否则id就不是从1开始了!!!)

建议以方式3导入,注意导入的时候ID字段的ID 要大写,不是小写。

补充知识:

postgresql 中表的字段,id字段,为整形自增字段,并且插入一条数据之后,该id是从1开始,而不是从0开始。

用truncate命令清空表之后,id字段并不会清空变成1,还是会继续历史数据id往后自增。

这里需要注意一下,

1.如果truncate命令执行的时候,提示有相关的表存在引用,执行的时候,可以加上cascade参数,具体语法:

TRUNCATE TABLE 表1,表2,表3...... cascade

表和表之间用 逗号分隔;

https://stackoverflow.com/questions/2679854/postgresql-disabling-constraints

https://www.yiibai.com/html/postgresql/2013/080676.html

2. 如果我们确实有,把id字段重置的需求,那么可以用以下方式:(注意,此方式还原id序列,并不会将数据清空,用了该方法之后,如果原表中数据没有被清空,往原表里插入数据是会报id已存在的错误的,所以该命令要配合truncete使用。)

ALTER SEQUENCE 表名_id_seq RESTART WITH 1

表名_id_seq查看获取方式:

项目中需要清空postgresql数据库中的一些表的数据,并将主键自增字段设置为1,在使用truncate在清表的时候,不能将主键自增字段重置为1,所以尝试采用下面这种方面进行重置自增的主键字段:
ALTER SEQUENCE tab_seq RESTART WITH ;
其中,tab_seq为表的序列标识(使用pgAdmin III软件序列标识位于数据库/数据库名/模式/序列/查找需要重置的序列)

odoo开发笔记 -- odoo和postgresql数据库导入相关的更多相关文章

  1. odoo开发笔记 -- odoo源码解析

    odoo 源码解析:http://blog.csdn.net/weixin_35737303

  2. odoo开发笔记--odoo可用小图标

    odoo系统的小图标都采用了 fontawesome字体图标 官网: http://fontawesome.dashgame.com/ Github:http://fortawesome.github ...

  3. odoo开发笔记 -- odoo权限管理

    odoo框架 整体权限可以分为4个级别: (1) 菜单级别: 不属于指定菜单所包含组的用,看不到相应菜单.不安全,只是隐藏菜单,若用户知道菜单ID,仍然可以通过指定URL访问(2) 对象级别: 对某个 ...

  4. odoo开发笔记 -- odoo快速开发技巧

    1. 需求分析到位 2. 系统对接,角色用例,数据串接 ---确定,轻易不可变更 3. 业务流程拆分细化 出图--开发人员理解的地步 4. 数据模型建立 --对应角色用例 5. 确立开发计划,划分功能 ...

  5. odoo开发笔记 -- odoo仪表板集成hightcharts

    highcharts图表插件初探 http://www.cnblogs.com/liubei/p/highchartsOption.html

  6. odoo开发笔记 -- odoo web机制浅析

    http://blog.csdn.net/M0relia/article/details/39025947

  7. odoo开发笔记 -- div标签代替odoo button写法

    odoo开发笔记 -- div标签代替odoo button写法 并调用自定义js <footer> <div id="confirm_request_cloud_repo ...

  8. odoo开发笔记 -- 搜索视图继承扩展

    odoo开发笔记 -- 搜索视图继承扩展

  9. odoo开发笔记 -- 后台日志输出及分析

    odoo开发笔记 -- 后台日志输出及分析 附:日志分析软件

随机推荐

  1. vbs解析 JSON格式数据

    Function jsonParser(str,jsonKey) Set sc = CreateObject("MSScriptControl.ScriptControl") sc ...

  2. 证明解析函数u=c1 与 v=c2 正交

    方程u(x,y)=c1对应平面上的曲线, 求导dy/dx=  -ux/uy   类似有v曲线的dy/dx=-vx/vy   两者相乘,使用柯西-黎曼方程结果是-1 表示在相交点两者的切线互相垂直. 另 ...

  3. 实现数组(java)

    一,数组 java中有对数组的数据结构:数组就是一个存放固定数据的结构. 数组的声明举例:int [] array=new int [3],与之相同的是private  in [ ] array; a ...

  4. UVaLive 3641 Leonardo's Notebook (置换)

    题意:给定一个置换 B 问是否则存在一个置换 A ,使用 A^2 = B. 析:可以自己画一画,假设 A = (a1, a2, a3)(b1, b2, b3, b4),那么 A^2 = (a1, a2 ...

  5. rpcbind.service启动失败

    新装的服务器,启动rpcbind.service通常失败,执行下面的两个命令经常卡死,一直不返回,也不报错 #systemctl start nfs-server.service #systemctl ...

  6. How to resolve "your security settings have blocked an untrusted application from running" in Mac

    If you encounter the error "your security settings have blocked an untrusted application from r ...

  7. kepware http接口 GO语言开发

    读取某变量的值 package main import ( "fmt" "net/http" "io/ioutil" ) func main ...

  8. thrift学习总结

    thrift 重要的几个组件有 :数据类型,transport,protocol,versioning,processor 1.数据类型 thrift的数据类型有1.一些原生类型,比如string,i ...

  9. POJ2594 Treasure Exploration(最小路径覆盖)

    Treasure Exploration Time Limit: 6000MS   Memory Limit: 65536K Total Submissions: 8550   Accepted: 3 ...

  10. vc6中向vs2010迁移的几个问题

    vc6版本支持的库编译:CJ60lib 1. 用vs2010打开CJ60库的源码的dsw,强制打开 (1)设置项目属性的语言 因为,如果代码字符的编码集不一样,则会出现函数冲定义,参数冲突等问题,这可 ...