`
pypy
  • 浏览: 92123 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

python adodb 支持mysql非标准端口

阅读更多
python对数据库的操作大多是基于

MySQLdb 模块

http://mysql-python.sourceforge.net/

但是,一般情况下大家都很少直接去调用 MySQLdb 去操作数据库

大多会借助

adodb

http://phplens.com/lens/adodb/adodb-py-docs.htm

小用了一下 adodb发现,还是比较强大的,(简单,直观)

import adodb;
conn = adodb.NewADOConnection('mysql')
conn.Connect('server','user','pwd','db')
cursor = conn.Execute('select * from table')

while not cursor.EOF:
	print cursor.fields
	cursor.MoveNext()

cursor.Close()
conn.Close() 


这样用了一段时间,突然,DBA那边说,数据库需要复用下,又安装了一个mysql,即是两个mysql在一台机器上并存,占用不同的端口
标准端口(3306)
另外一个端口(3307)

再修改程序的时候发现,adodb根本就没有修改port的选项,

为了,不改动太多的已有代码,

于是乎,see了see ,adodb的源码,

(既然 MySQLdb 支持非标准port, 而 adodb是封装了MySQLdb,那就有办法搞搞)

1. 第一步
adodb-220/adodb/adodb.py

194     def Connect(self,host=None,user=None,password=None,database=None):
195         self.database = database
196         self.host = host
197         self.user = user
198         self.password = password
199         self._connect(host,user,password,database)
200         return bool(self._conn)

增加对 port的支持(其实就是增加从 adodb这边把port参数传入到 MySQLdb 那边就可以了)
修改如下

194     def Connect(self,host=None,user=None,password=None,port=None,database=None):
195         self.database = database
196         self.host = host
197         self.user = user
198         self.password = password
199         self.port = port
200         if self.port is None:
201             self._connect(self.host,self.user,self.password,self.database)
202         else:
203             self._connect(self.host,self.user,self.password,self.database,self.port)
200         return bool(self._conn)


2. 第二步, 因为我是使用mysql,所以,只是去改动了adodb_mysql.py
   如果你是使用其他数据库,类同,修改之

34     def _connect(self,host=None,user=None,password=None,database=None):
35         self._conn = MySQLdb.connect(host, user, password, database)

修改如下

34     def _connect(self,host=None,user=None,password=None,database=None, port=None):
35         self._conn = MySQLdb.connect(host, user, password, database, port)


经过以上2步修改即可,(比较山寨哈)

使用例子

import adodb
conn = adodb.NewADOConnection('mysql')
conn.Connect('10.10.10.1', 'user', 'password', 'mydb',3307)

分享到:
评论
6 楼 jjx 2009-07-09  
在python中,一般adodb 都是指adodbapi,而不是你说的那个adodb了,你的说法有误了,当然,你这样说也没什么问题

如果用要抽象一点的,我觉的除了sqlalchemy的python expression,没有什么其它可推荐的了
5 楼 pypy 2009-07-08  
jjx 写道
一般用的都是adodbapi吧,不是你说的这个adodb(我也是第一次看到这个) .
adodbapi 使用的是oledb,sql server是
data source=ip,port, mysql安装odbc或是oledb 驱动后,在连接字符串中加入port=xxx即可


不好意思,我使用的是mysql数据库

这个帖子讨论的是

http://phplens.com/lens/adodb/adodb-py-docs.htm

这个模块, 其他的一些数据库连接模块可能会支持标准之外的端口,但是

python 的 adodb 的确不支持连接除标准端口之外的端口

其他的数据库连接模块,我也会去试着用的,

还有一个模块比较好的,在python中

http://www.webwareforpython.org/DBUtils

打算以后的数据库连接模块,采用这个模块了,大家可以一起讨论下这个 支持连接池的

4 楼 jjx 2009-07-08  
一般用的都是adodbapi吧,不是你说的这个adodb(我也是第一次看到这个) .
adodbapi 使用的是oledb,sql server是
data source=ip,port, mysql安装odbc或是oledb 驱动后,在连接字符串中加入port=xxx即可
3 楼 pypy 2009-07-08  
haijd 写道
在主机名那里加端口号不行吗?例如“localhost:3307”


你说的这个方法,我还没有试过,应该是不行的吧,

2 楼 haijd 2009-07-07  
在主机名那里加端口号不行吗?例如“localhost:3307”
1 楼 langyu 2009-06-15  
对技术不懂,只能坐沙发了

相关推荐

    php 使用ADODB操作MYSQL

    在PHP开发中,数据库操作是不可或缺的一部分,而ADODB(Active Record Object Database Abstraction Layer)是一个流行的数据库抽象层,它提供了统一的接口来处理多种数据库系统,包括MySQL。本篇文章将详细探讨如何...

    ADODB-mysql for Mono-开源

    1. **跨平台迁移**:如果你有一个使用ADODB与MS SQL Server交互的.NET应用,现在想要迁移到Linux或其他非Windows系统,ADODB-mysql库可以帮助你快速转换到MySQL,而无需重写大量数据库访问代码。 2. **简化开发**:...

    ADODB类应用模块源码

    在IT行业中,ADODB(ActiveX Data Objects Database)是一个广泛使用的接口,用于访问数据库,尤其在微软的Windows环境中。这个接口允许程序员通过编程语言(如VBScript、VBA或Visual Basic)与各种数据库系统交互,...

    adodb.zip_ACCESS数据库_access mysql_adodb mysql_adodb-time.inc.php

    本主题聚焦于如何使用ADODB(ActiveX Data Objects Database)库从Access数据库向MySQL数据库迁移数据。ADODB是一个强大的、跨平台的数据库访问组件,它允许程序员使用相同的接口来处理多种数据库系统,如Access、...

    PHP开发的企业网站源码 PHP+Smarty+Adodb+MySql

    它支持变量替换、条件语句、循环结构等模板语法,使得非程序员也能轻松编辑模板。 Adodb(Active Record Database Abstraction Library)是PHP中的一个数据库抽象层,允许开发者在不同的数据库系统间切换,如MySQL...

    易语言adodb支持库

    易语言是一种专为中国人设计的编程语言,它以简化的语法和中文命令名称为特点,降低了编程的门槛,使得更多非计算机专业的人也能轻松学习编程。在易语言中,"adodb支持库"是一个重要的模块,它允许程序员通过易语言...

    adodb.zip_adodb_collegekdk_connect_php4 mysql adodb_syllablexpe

    标题中的"adodb.zip_adodb_collegekdk_connect_php4_mysql_adodb_syllablexpe"揭示了这个压缩包的内容主要涉及ADODB库在PHP4版本中连接MySQL数据库的应用,同时可能包含一个或多个与"collegekdk"相关的项目或教程,...

    ADODB5中文手册.docx

    3. 广泛支持:ADODB当前支持的数据库有MySQL, PostgreSQL, Oracle, Interbase, Microsoft SQL Server, Access, FoxPro, Sybase, ODBC和ADO。 四、使用ADODB连接MySQL 下面是一个使用ADODB连接MySQL的示例代码: `...

    ADODB数据驱动操作支持库

    这个“ADODB数据驱动操作支持库”很可能是一个包含ADODB接口的组件或者类库,用于简化和增强开发者对数据库的操作能力。下面我们将深入探讨ADODB的核心概念、功能以及如何使用它进行数据库操作。 ADODB主要由以下几...

    mysql-connector-odbc-5.3.10-win32.rar

    在编程环境中,如Python的pyodbc库或VBA中的ADODB对象,开发者可以使用这些配置好的DSN来建立连接,执行SQL查询,插入、更新或删除数据。例如,在Python中,可以通过以下代码连接到MySQL数据库: ```python import ...

    PHP的adodb类库

    ADODB支持多种数据库驱动,包括PDO、MySQLi、MySQL、SQLite、Oracle等。通过统一的接口,开发者可以轻松切换数据库平台,无需修改大量代码。例如,`ADODB`提供`Connect()`和`PConnect()`函数来建立持久或非持久连接...

    易语言学习-ADODB数据库操作支持库 (1.4#3版).zip

    易语言是一种专为中国人设计的编程语言,它以简明的中文语法,降低了编程的门槛,使得更多非专业程序员能够快速上手。在易语言的学习过程中,数据库操作是不可或缺的一部分,尤其是在自动化和脚本编写中,数据库的...

    adodb中文帮助文档

    adodb php连接数据库,中文帮助文档

    ADODB数据驱动操作支持库2.0#6版(第三方) (2)

    本文将深入探讨ADODB数据驱动操作支持库2.0#6版,这是一个第三方提供的易语言支持库,适用于易语言编程环境。 易语言是一种以“中文编程”为特色的编程语言,旨在降低编程难度,提高开发效率。易语言教程和模块等...

    Python操作Access数据库基本步骤分析

    在Python编程中,与Access数据库进行交互是常见的任务,尤其在处理小型数据存储或Windows环境下的应用程序时。本篇文章将详细解析Python操作Access数据库的基本步骤,并提供实例代码以供参考。 首先,确保你已经...

    ADODB 手册。

    ADODB(ActiveX Data Objects Database)是一个开源的数据库访问库,尤其在PHP环境中广泛应用,用于与各种数据库系统进行交互,包括MySQL、Oracle、SQL Server等。这个手册将深入讲解ADODB的关键概念、功能和用法。 ...

    adodb

    AdODB支持多种数据库连接方式,包括PDO、mysqli和旧版的mysql扩展。通过`ADONewConnection`函数,你可以轻松创建到指定数据库的连接。例如,连接到MySQL数据库: ```php $db = ADONewConnection('mysqli'); $db-...

    php adodb文件包

    此外,ADODB支持事务处理,这对于处理复杂的数据库操作至关重要: ```php $connection->BeginTrans(); try { // 执行一系列数据库操作 $connection->Execute('INSERT INTO table (col1, col2) VALUES (?, ?)', ...

    php adodb操作mysql数据库

    ADODB是一个数据库访问层,它允许开发者通过一个统一的接口来连接和操作各种类型的数据库系统,包括MySQL、Oracle、PostgreSQL等。ADODB是Active Data Objects Database的缩写,它为数据库操作提供了一个更加方便和...

Global site tag (gtag.js) - Google Analytics