Python3.x:使用PyMysql连接Mysql数据库
Python3.x完全不向前兼容,导致Python2.x中可以正常使用的库,到了Python3就用不了;
比如说mysqldb,目前MySQLdb并不支持Python3.x , Python3.x连接MySQL的方案有:oursql, PyMySQL, myconnpy 等
PyMsql链接Mysql数据库步骤:
1,PyMysql安装
PyMysql就是作为Python3环境下mysqldb的替代物,进入命令行,使用pip安装pymysql:
pip install pymysql3
安装结果:
2,PyMysql连接数据库(增、删、改、查)示例
#导入pymysql的包 import pymysql try: #获取一个数据库连接,注意如果是UTF-8类型的,需要制定数据库 conn=pymysql.connect(host='localhost',user='pythondb',passwd='pythondb',db='pythondb',port=3306,charset='utf8') cursor=conn.cursor()#获取一个游标 #创建user表 cursor.execute("drop table if exists user") sql="""CREATE TABLE IF NOT EXISTS `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `age` int(11) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=0""" cursor.execute(sql) #user插入数据 sql="""INSERT INTO `user` (`name`, `age`) VALUES ('test1', 1), ('test2', 2), ('test3', 3), ('test4', 4), ('test5', 5), ('test6', 6);""" try: # 执行sql语句 cursor.execute(sql) # 提交到数据库执行 conn.commit() except: # 如果发生错误则回滚 conn.rollback() #更新 id=1 sql="update user set age=100 where id='%s'" % (id) try: cursor.execute(sql) conn.commit() except: conn.rollback() #删除 id=2 sql="delete from user where id='%s'" % (id) try: cursor.execute(sql) conn.commit() except: conn.rollback() #查询 cursor.execute('select * from user') results=cursor.fetchall() # 判断是否有记录数 if len(results) == 0: check_code = 0 else: check_code = 1 #取出数据 for row in results: name=row[0] age=row[1] #print(type(row[1])) #打印变量类型 print ("name=%s,age=%s" %(age, name)) cursor.close()#关闭游标 conn.close()#释放数据库资源 except Exception :print("失败")