关于openerp中create的不解
-
我是一名开发人员,现在在学习开发openerp 现在遇到一个关于create的问题,有点不解,希望老鸟们指点指点。
我想通过pymssql 将mssql中现有的数据 导入到openerp中备用 现在已经可以导入成功了,但却多了一条id为0的数据
表结构很简单(id,name) form中 只有一个button 我很纳闷不知怎么回事。 现在将 id和name 添加到form中,
输入值后 点击button,界面上的数据先写入,然后是MSSQL的数据,我现在只想写自己的数据 怎么做?
以下是 xml代码<br /> <!--定义表单视图--><br /> <record model="ir.ui.view" id="view_mynorthwind_categories_form"><br /> <field name="name">mynorthwind.categories.form</field><br /> <field name="type">form</field><br /> <field name="model">mynorthwind.categories</field><br /> <field name="arch" type="xml"><br /> <form><br /> <button name="categories_writer" type="object" string="导入MSSQL数据"/><br /> </form><br /> </field><br /> </record><br /> <br /> <!--定义列秒视图--><br /> <record model="ir.ui.view" id="view_mynorthwind_categories_tree"><br /> <field name="name">mynorthwind.categories.tree</field><br /> <field name="type">tree</field><br /> <field name="model">mynorthwind.categories</field><br /> <field name="arch" type="xml"><br /> <tree><br /> <field name="categoriesId"/><br /> <field name="categoriesName"/><br /> </tree><br /> </field><br /> </record><br />
以下是 py代码<br /># -*- coding: utf-8 -*-<br />from osv import osv<br />from osv import fields<br />import pymssql<br /><br /><br />class mynorthwind_categories(osv.osv):<br /> <br /> _name='mynorthwind.categories'<br /> _description='分类'<br /> _columns={<br /> 'categoriesId':fields.integer('ID'),<br /> 'categoriesName':fields.char('Name',size=128)<br /> }<br /> <br /> def categories_writer(self, cr, uid, ids, context=None):<br /> print "begin connect to the server RD5"<br /> conn=pymssql.connect(server="RD5-hgh",user="sa",password="permain",database="mynorthwind",charset="UTF-8")<br /> print "connect success"<br /> cur = conn.cursor()<br /> sql = "SELECT top 10 CategoryID,CategoryName FROM Categories"<br /> cur.execute(sql)<br /> resault=cur.fetchone()<br /> i=0<br /> while resault:<br /> print "categoriesId=%s , categoriesName=%s" % (resault[0], resault[1])<br /> rowid= self.create(cr, uid,{ 'categoriesId':resault[0] ,'categoriesName':resault[1] })<br /> resault = cur.fetchone() <br /> conn.close() <br />mynorthwind_categories()<br />
console 结果<br />pydev debugger: starting<br />begin connect to the server RD5<br />connect success<br />categoriesId=1 , categoriesName=手机<br />categoriesId=2 , categoriesName=MP3/4<br />categoriesId=3 , categoriesName=U盘<br />categoriesId=4 , categoriesName=存储卡<br />categoriesId=5 , categoriesName=项链<br />categoriesId=6 , categoriesName=手链<br />categoriesId=7 , categoriesName=耳环<br />categoriesId=8 , categoriesName=发饰<br />categoriesId=9 , categoriesName=Test statistics<br />
SQL 查询结果
CategoryID CategoryName
----------- --------------------
1 手机
2 MP3/4
3 U盘
4 存储卡
5 项链
6 手链
7 耳环
8 发饰
9 Test statistics
OE里面的数据(图片不知道怎么上传,手动打上去的)
ID NAME
0
1 手机
2 MP3/4
3 U盘
4 存储卡
5 项链
6 手链
7 耳环
8 发饰
9 Test statistics
1 手机
2 MP3/4
3 U盘
4 存储卡
5 项链
6 手链
7 耳环
8 发饰
9 Test statistics
这是点击2次后的结果
很明显 当表里面的数据为空的时候 会默认的插入一条 ID=0 的数据
我想去掉这条数据 怎么操作?
这样描述 应该很清楚吧 -
[quote author=Joshua link=topic=6716.msg15996#msg15996 date=1369818824]
没看明白,你的从mysql读出来的resault是10条,执行create后,openerp有11条(多了id=0的)?
[/quote]
是的 很奇怪 不知道为什么会这样 -
多出来的记录值是什么?是重复值还是空值。为什么要用super? 类名也用的奇怪
-
[quote author=digitalsatori link=topic=6716.msg16003#msg16003 date=1369839636]
多出来的记录值是什么?是重复值还是空值。为什么要用super? 类名也用的奇怪
[/quote]
多出来的记录是 id:0 name 空, 我读到的数据是 id:1,name:xxxx 这样的数据,id从1开始到9
用super 是因为在点击按钮的时候 会自动执行create方法一次,想重写
类名奇怪? 自己测试用的 不知道openerp对名称有什么特别的要求? -
[quote author=Li.Wei link=topic=6716.msg15999#msg15999 date=1369828652]
我觉得你的意思是,要保持导入之前的记录和OE里的记录,ID一致,是么?
[/quote]
是的 我读出来的数据是 1到9 但写入后 却多了一个id=0 name=空的记录 -
[quote author=mrshelly link=topic=6716.msg16000#msg16000 date=1369834010]
你的循环没有用对....
[/quote]
没用对?但我的数据已经全部写入oe了啊 -
[quote author=l315276651 link=topic=6716.msg16007#msg16007 date=1369880356]
[quote author=mrshelly link=topic=6716.msg16000#msg16000 date=1369834010]
你的循环没有用对....
[/quote]
没用对?但我的数据已经全部写入oe了啊
[/quote]
数据已写入, 也不表明你的循环就正确啊.
如果你的循环多运行了一次. 你想想后果是什么样子的?
五条记录, 你想象中 应该是循环五次, 每次插入一条记录,
但是,如果你的循环用错了. 你循环里的代码运行了六次. 那结果会如何呢? 当然, 这只是假设. -
[quote author=mrshelly link=topic=6716.msg16016#msg16016 date=1369955570]
[quote author=l315276651 link=topic=6716.msg16007#msg16007 date=1369880356]
[quote author=mrshelly link=topic=6716.msg16000#msg16000 date=1369834010]
你的循环没有用对....
[/quote]
没用对?但我的数据已经全部写入oe了啊
[/quote]
数据已写入, 也不表明你的循环就正确啊.
如果你的循环多运行了一次. 你想想后果是什么样子的?
五条记录, 你想象中 应该是循环五次, 每次插入一条记录,
但是,如果你的循环用错了. 你循环里的代码运行了六次. 那结果会如何呢? 当然, 这只是假设.
[/quote]
可以确认的是 循环没有问题 每写一次数据我都print 出来写入的数据。现在的问题点是 在我开始循环写入数据之前
OE就自动的帮我写入了一条数据,这条数据就是在tree页面 点击create后自动产生的,点击button后 oe会先写入这条
数据 然后才执行我的function ,我猜测 这是oe的一种机制。不知道有什么办法 可以屏蔽系统自动创建的数据 -
[quote author=mrshelly link=topic=6716.msg16026#msg16026 date=1369966522]
嗯. 问题就在这里.
你不应该到本身这个对象的 form view
而应该是一个 wizard (osv.osv_memory || osv.Model) 内存对象...
[/quote]
有点不明白 不知道 源码中 有相应的demo吗? -
首先感谢@mrshelly大大的回复。
@l315276651 的问题主要出在当你打开一个表单视图的时候,点击任何按钮,服务器首先第一步是把你当前的表单视图保存(估计你的表单里面没有必填字段,所以会保存 名字:空 ,xx字段:空),id=0就这样出来了。如果你是打开一条原有的数据的表单视图再点击你的按钮,估计就不会再生成这条id=0。
解决办法:
1.用wizard(osv.osv_memory || osv.TransientModel) 估计mrshelly回复里面有个笔误。(具体代码可以看其他模块的wizard文件夹),openerp里面的动作(按钮,菜单)一般都要绑定一个model,而这里如果用了osv.TransientModel,首先他会弹出你定义的TransientModel的视图,点击按钮后也会保存一个TransientModel的记录,但是这个记录系统会隔一段时间自动清空。
2.你可以使用server action,action type 选择 python code(里面可以写你的自己的方法), 然后把server action可以绑定到菜单上,这个server action虽然也要绑定一个model,不过并不需要开启该model的任何表单。 -
感谢mrshelly和Joshua 2位大大的回复
让我进一步的了解了OE
继续学习OE 支持OE ;D