阅 读 文 章

关于不同数据库之间图像数据移植的心得和疑问

[来源:网上转载 (http://www.chinaunix.net) | 作者:网友(秋池飞叶) | 时间:2007-05-27 | 浏览:人次 ]



然后: ss = array.array('B',ss).tostring()

又得到一个字符串~! 你可能会说我带你绕弯那,转来转去又转成字符串了。这也是我的疑问所在:

为什么从mysql里获取array后,使用tostring()方法得到的字符串不能直接插到sybase里,而使用
ss = array.array('B',ss)得到一个列表,然后把这个列表转换成一个字符串就可以了哪?
我对比过这两个字符串,并没有转义特殊字符。关于这一点,恳请前辈指教。

好了,现在我们可以把 ss = array.array('B',ss).tostring() 转换后的字符串插到sybase的imagerow里了:

c.execute("update imagetable set imagerow='%s'"%(ss))

但是每个数据库的特性也决定了写入图像数据的时候有不同的方法,如果对于mysql,这样做就可以了,
但是对与sybase,这样做其实并没有把数据真正写入,只写入了图像的基本信息。还需要用如下方法。

c.execute("select imagerow from imagetable where imageid='xx'")

r = c.getImageDesc(0)

c.writeImageData(r[0],ss)

如果返回1代表成功,0代表失败。

至此,从mysql里选择的图像数据才真正写入sybase里了。

这个脚本整理一下大概是这样:

import MySQLdb
import Sybase
import array

dbmysql = MySQLdb('localhost','root','','testdb')
dbsybase = Sybase('database_server_name','user','pswd','testdb')

my = dbmysql.cursor()
sy = dbsybase.cursor()

my.execute("select imagerow from imagetable where imageid='xx'")
b = my.fetchone()
b = b[0].tostring()
b = array.array('B',b)
ss = array.array('B',b).tostring()

sy.execute("update imagetable set imagerow='%s' where imageid='xx'"%(ss))
dbsybase.commit()

sy.execute("select imagerow from imagetable where imageid='xx'")
r = sy.getImageDesc(0)

sy.writeImageData(r[0],ss)






另外要说明几点:

要把一个图像数据写入mysql里的时候,要用MySQLdb.escape_string(ss) 把字符串的特殊字符转义掉。
关于这一点在《python cookbook》一书中有详细说明。 

如果你操作的是informix数据库,那么用select 语句查出来的图像数据是一个dbiRaw对象,你需要
str(dbiRaw)转换成字符串。

这些是我这几天的心得和疑问,如果有什么不对的地方恳请指点一二。



 秋池飞叶 回复于:2006-10-15 11:19:29

晕,怎么都没反应阿


 xichen 回复于:2006-10-15 15:12:02

加了精华了


 秋池飞叶 回复于:2006-10-15 16:03:45

谢谢斑竹~


 limodou 回复于:2006-10-15 18:19:36

因为没用过,所以没什么意见,呵呵。


 秋池飞叶 回复于:2006-10-16 16:04:06

没有用python作数据库操作的吗?一起探讨一下撒


 xie_minix 回复于:2006-10-23 14:43:51

我在把windows平台下的DBF文件转到NETBSD下的MYSQL下去,也碰到了一些问题.移植结束后看看有什么体会也来谈谈.


 秋池飞叶 回复于:2006-10-23 17:58:32

引用:原帖由 xie_minix
论坛热门帖子: [lch203] 写得蛮好的linux学习笔记(10-21)
[黑马制造] 学习java的30个目标(10-19)
[笑傲股林] 做测试半年了,有点迷茫,应该再学些什么提高自己的测试水平和测试能力呢?(10-19)
[udp8589] 大家用google的来吱一声? 用百度的~~也来报道下?(10-18)
[沂偌掳兆] 本人总结的一些认为C++比较经典的书籍,希望对大家有用(10-18)
TAG标签: 移植 心得 疑问 数据 图像 不同 数据库 之间 关于 x00

最新评论 共有0位网友发表了评论

发表评论

评论内容:不能超过250字,需审核,请自觉遵守互联网相关政策法规。
用户名:(注册)
密码:
验证码:
匿名发表

网站地图友情连接交流论坛网站投稿广告服务联系我们留言本站长统计
Some rights reserved: www.chmhome.com, 鄂ICP备07010232号 E-mail:chinakafei@live.com,QQ:552766
中国咖啡技术网(Chmhome):国外编程技术书籍,中文编程手册,经典编程文章,交流技术,技术软件下载,计算机论文,毕业论文.