0

我在mysql中有一个表,如下所示:

CREATE TABLE `province` (
  `pid` int(2) unsigned zerofill NOT NULL,
  `pname` varchar(255) CHARACTER SET utf8 COLLATE utf8_persian_ci DEFAULT NULL,
  `family` int(12) DEFAULT NULL,
  `population` int(11) DEFAULT NULL,
  `male` int(11) DEFAULT NULL,
  `female` int(11) DEFAULT NULL,
  PRIMARY KEY (`pid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_persian_ci

请注意,第一列(pid)是零填充列,表(省)中的数据如下:

=========================================
|pid|pname|family|population|male|female|
=========================================
|02 | 'A' |  12  |    20    |  8 |   5  |
=========================================
|03 | 'B' |  25  |    20    |  7 |   6  |
=========================================
|05 | 'c' |  34  |     5    |  7 |   9  |
=========================================

我想通过 python 检索 pid 列,所以我的 python 代码是:

import mysql.connector

if __name__ == '__main__':
    data = []
    res = []
    cnx = mysql.connector.connect(user='mehdi', password='mehdi', host='127.0.0.1', database='cra_db')
    cursor = cnx.cursor()
    qrystr = 'SELECT pid FROM province;'
    cursor.execute(qrystr)
    print(cursor.fetchall())
    cnx.close()     

但是当我运行这个python代码时,发生了这个异常:

返回带有错误集的结果 File "C:\Users\M_Parastar\Desktop\New folder\ttt.py", line 11, in print(cursor.fetchall())


你知道如何通过python检索零填充列吗?

4

1 回答 1

0

游标返回一个可迭代的 Python 对象,将“print(cursor.fetchall())”替换为“for rows in cursor: print (rows)”。访问连接器/Python API 参考

于 2018-11-05T05:41:53.223 回答