URN Logo
UNIX Resources » Linux » China Linux Forum » Python 编 程 » 5 » mxodbc postgresql 大对象问题
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
mxodbc postgresql 大对象问题
mxodbc postgresql 大对象问题 - llxxx [2005-10-27 12:03 | 792 byte(s)]
 
Re: mxodbc postgresql 大对象问题 - limodou [2005-10-27 15:24 | 376 byte(s)]
 
Re: mxodbc postgresql 大对象问题 - llxxx [2005-10-28 09:49 | 351 byte(s)]
 
Re: mxodbc postgresql 大对象问题 - limodou [2005-10-28 13:51 | 286 byte(s)]
 
Subject: mxodbc postgresql 大对象问题
Author: llxxx    Posted: 2005-10-27 12:03    Length: 792 byte(s)
[Original] [Print] [Top]
往postgresql里存储一个大对象(bytea)
import mx.ODBC.Windows
conn=mx.ODBC.Windows.Connect(dsn, user, pass)
cur=conn.cursor()
f=open('e:/test/asdf.txt', 'rb')
cur.execute("insert into python(data) values('%s')" % b)
这个用以上的代码,如果文件是ascii文件,是可以的,但如果
是二进制的就出错
网上查了一条语句:
cursor.execute("""INSERT INTO document (content)
VALUES (%s)""" , (txt,))
但是也不行,以下是error code
cur.execute("""insert into python (data) values(%s)""",(b,))
mxODBC.InterfaceError: number of parameters in tuple 0: expected 0, found 1
问一下各位大侠,这个到底应该怎样?
[Original] [Print] [Top]
Subject: Re: mxodbc postgresql 大对象问题
Author: limodou    Posted: 2005-10-27 15:24    Length: 376 byte(s)
[Original] [Print] [Top]
cur.execute("""insert into python (data) values(%s)""",(b,))
这行语句写错了。少了一个%号。应该为:

cur.execute("""insert into python (data) values(%s)""" % b)

如果只有一个参数,不需要写成tuple的形式。

如果还有数据库的问题那就要看数据库方式的参考了。
----
[Original] [Print] [Top]
Subject: Re: mxodbc postgresql 大对象问题
Author: llxxx    Posted: 2005-10-28 09:49    Length: 351 byte(s)
[Original] [Print] [Top]
问题是这样的,b是从一个二进制文件里读的数据,是一个str
现在我的sql语句是:
sql="""insert into python values(1010,200,'%s')""" % b
在python中会被认做:
insert into python values(1010,200,'MZ?)
我的问题是如何保证在这个sql语句中的b是他原来的样子?
也就是这条sql语句该怎么写?
[Original] [Print] [Top]
Subject: Re: mxodbc postgresql 大对象问题
Author: limodou    Posted: 2005-10-28 13:51    Length: 286 byte(s)
[Original] [Print] [Top]
大型数据库都有blob类型的数据类型,而且它们的插入方法一般也不是普通的sql语句可以做到的,因此你需要看数据库的使用说明,比如sql中关于blob使用的内容。这个我也不是很清楚了。至少我见过informix就不是这样操作的。当然我使用的也不是python了。

有的blob分为text和binary两种类型。
----
[Original] [Print] [Top]
« Previous thread
用python来打乱排序后的文件
Python 编 程
5
Next thread »
探讨一下这篇文章
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 04:11:01, cost 0.038226127624512 ms.