python36与mysql
在 Python 语言环境下我们这样连接数据库。
In [1]: from mysql import connector
In [2]: cnx = connector.connect(host="172.16.192.100",port=3306,user="appuser",password="xxxxxx")
但是连接数据库的背后发生了什么呢?
答案
当我们通过驱动程序(mysql-connector-python,pymysql)连接 MySQL 服务端的时候,就是把连接参数传递给驱动程序,驱动程序再根据参数会发起到 MySQL 服务端的 TCP 连接。当 TCP 连接建立之后驱动程序与服务端之间会按特定的格式和次序交换数据包,数据包的格式和发送次序由MySQL 协议规定。MySQL 协议:https://dev.mysql.com/doc/internals/en/client-server-protocol.html整个连接的过程中 MySQL 服务端与驱动程序之间,按如下的次序发送了这些包。
MySQL 服务端向客户端发送一个握手包,包里记录了 MySQL-Server 的版本,默认的授权插件,密码盐值(auth-data)。
2. MySQL 客户端发出 ssl 连接请求包(如果有必要的话)。
3. MySQL 客户端发出握手包的响应包,这个包时记录了用户名,密码加密后的串,客户端属性,等等其它信息。
4. MySQL 服务端发出响应包,这个包里记录了登录是否成功,如果没有成功也会给出错误信息。
㈡ MySQL数据库和Python如何结合
首先我们需要的是一个MySQLdb的库。使用import来进行测试看是否存在,这个样子就是存在的。
使用
#! /usr/bin/python
# -*- coding: UTF-8 -*-
来支持中文。
使用import MySQLdb导入库
使用connect进行数据库的连接。db=MySQLdb.connect('127.0.0.1','root','root','myself')
然后使用db.curspor()方法来获取。
最后进行sql语句执行查询命令就可以了。
㈢ python3.6执行pymysql报错
折腾好半天的数据库连接,由于之前未安装 pip ,而且自己用的Python 版本为3.6. 只能用 pymysql 来连接数据库,下边 简单介绍一下 连接的过程,以及简单的增删改查操作。
1.通过 pip 安装 pymysql
进入 cmd 输入 pip install pymysql
回车等待安装完成;
安装完成后出现如图相关信息,表示安装成功。
2.测试连接
import pymysql #导入 pymysql ,如果编译未出错,即表示 pymysql 安装成功
简单的增删改查操作
示例表结构
2.1查询操作
[python] view plain
import pymysql #导入 pymysql
#打开数据库连接
db= pymysql.connect(host="localhost",user="root",
password="123456",db="test",port=3307)
# 使用cursor()方法获取操作游标
cur = db.cursor()
#1.查询操作
# 编写sql 查询语句 user 对应我的表名
sql = "select * from user"
try:
cur.execute(sql) #执行sql语句
results = cur.fetchall() #获取查询的所有记录
print("id","name","password")
#遍历结果
for row in results :
id = row[0]
name = row[1]
password = row[2]
print(id,name,password)
except Exception as e:
raise e
finally:
db.close() #关闭连接
2.2插入操作
[python] view plain
import pymysql
#2.插入操作
db= pymysql.connect(host="localhost",user="root",
password="123456",db="test",port=3307)
# 使用cursor()方法获取操作游标
cur = db.cursor()
sql_insert ="""insert into user(id,username,password) values(4,'liu','1234')"""
try:
cur.execute(sql_insert)
#提交
db.commit()
except Exception as e:
#错误回滚
db.rollback()
finally:
db.close()
2.3更新操作
[python] view plain
import pymysql
#3.更新操作
db= pymysql.connect(host="localhost",user="root",
password="123456",db="test",port=3307)
# 使用cursor()方法获取操作游标
cur = db.cursor()
sql_update ="update user set username = '%s' where id = %d"
try:
cur.execute(sql_update % ("xiongda",3)) #像sql语句传递参数
#提交
db.commit()
except Exception as e:
#错误回滚
db.rollback()
finally:
db.close()
2.4删除操作
[python] view plain
import pymysql
#4.删除操作
db= pymysql.connect(host="localhost",user="root",
password="123456",db="test",port=3307)
# 使用cursor()方法获取操作游标
cur = db.cursor()
sql_delete ="delete from user where id = %d"
try:
cur.execute(sql_delete % (3)) #像sql语句传递参数
#提交
db.commit()
except Exception as e:
#错误回滚
db.rollback()
finally:
db.close()
㈣ python3.6.5 始终连接不上mysql8.0
#createdatabase.py
#!/usr/bin/envpython
importos
importre
importsys
importpymysql
fromimportlibimportimport_mole
#searchthedirnameofsettings.pyandimportit
withopen('manage.py')asf:
s=f.read()
d=re.search(r'DJANGO_SETTINGS_MODULE.*?,s*"(.+?).settings',s).group(1)
assert'settings.py'inos.listdir(d)
mo=import_mole('{d}.localsettings'.format(d=d))
defgetconf(alias='default'):
dbconf=mo.DATABASES.get(alias)
config={'host':dbconf.get('HOST'),
'user':dbconf.get('USER'),
'passwd':dbconf.get('PASSWORD'),
'port':dbconf.get('PORT'),
'charset':'utf8',}
config={k:vfork,vinconfig.items()ifvisnotNone}
db_name=dbconf.get('NAME')
returnconfig,db_name
defcreat_db(config,db_name):
try:
conn=pymysql.connect(**config)
cur=conn.cursor()
if'-d'insys.argv:
cur.execute('dropdatabase{}'.format(db_name))
print('successtoexecute`dropdatabase{};`'.format(db_name))
command='createdatabase{}_general_ci'.format(db_name)
cur.execute(command)
print('successtoexecute`{};`'.format(command))
#conn.select_db(database)
conn.commit()
cur.close()
conn.close()
exceptExceptionase:
print("SQLError:{e}".format(e=e))
defmain():
creat_db(*getconf())
#creat_db(*getconf('mysql_property'))
估计是密码错了,你直接在命令行运行:
mysql-uroot-proot
看看密码是不是root
㈤ 怎么将python和mysql数据库连接
在 Python 语言环境下我们这样连接数据库。
In [1]: from mysql import connector
In [2]: cnx = connector.connect(host="172.16.192.100",port=3306,user="appuser",password="xxxxxx")
但是连接数据库的背后发生了什么呢?
答案
当我们通过驱动程序(mysql-connector-python,pymysql)连接 MySQL 服务端的时候,就是把连接参数传递给驱动程序,驱动程序再根据参数会发起到 MySQL 服务端的 TCP 连接。当 TCP 连接建立之后驱动程序与服务端之间会按特定的格式和次序交换数据包,数据包的格式和发送次序由MySQL 协议规定。MySQL 协议:https://dev.mysql.com/doc/internals/en/client-server-protocol.html整个连接的过程中 MySQL 服务端与驱动程序之间,按如下的次序发送了这些包。
MySQL 服务端向客户端发送一个握手包,包里记录了 MySQL-Server 的版本,默认的授权插件,密码盐值(auth-data)。
2. MySQL 客户端发出 ssl 连接请求包(如果有必要的话)。
3. MySQL 客户端发出握手包的响应包,这个包时记录了用户名,密码加密后的串,客户端属性,等等其它信息。
4. MySQL 服务端发出响应包,这个包里记录了登录是否成功,如果没有成功也会给出错误信息。
㈥ python3.6可以连接mysql数据库吗
具体步骤:
序号
描述
1
去github上下载pymysql的安装包pymysql
2
解压到某个盘符下
3
打开cmd窗口(win环境下),进入pymysql的根目录下执行命令,python
setup.py
install
4
在程序里,导入pymysql
5
开始连接数据库
数据库操作的API文档连接:
㈦ windows的环境变量怎么设置多个啊。我想设置一个python的和一个mysql的。我是这样写的
环境变量都是路径,不是具体的一个文件,你写的前一半不对
多个环境变量用 分号 分开
原来已有的环境变量 最好不要动,只要在后面添加就行(前面也行),注意分号
㈧ python怎么和mysql链接
在 Python 语言环境下我们这样连接数据库。
In [1]: from mysql import connector
In [2]: cnx = connector.connect(host="172.16.192.100",port=3306,user="appuser",password="xxxxxx")
但是连接数据库的背后发生了什么呢?
答案
当我们通过驱动程序(mysql-connector-python,pymysql)连接 MySQL 服务端的时候,就是把连接参数传递给驱动程序,驱动程序再根据参数会发起到 MySQL 服务端的 TCP 连接。当 TCP 连接建立之后驱动程序与服务端之间会按特定的格式和次序交换数据包,数据包的格式和发送次序由MySQL 协议规定。MySQL 协议:https://dev.mysql.com/doc/internals/en/client-server-protocol.html整个连接的过程中 MySQL 服务端与驱动程序之间,按如下的次序发送了这些包。
MySQL 服务端向客户端发送一个握手包,包里记录了 MySQL-Server 的版本,默认的授权插件,密码盐值(auth-data)。
2. MySQL 客户端发出 ssl 连接请求包(如果有必要的话)。
3. MySQL 客户端发出握手包的响应包,这个包时记录了用户名,密码加密后的串,客户端属性,等等其它信息。
4. MySQL 服务端发出响应包,这个包里记录了登录是否成功,如果没有成功也会给出错误信息。
㈨ python连接MySQL数据库实例分析
python连接MySQL数据库实例分析
本文实例讲述了python连接MySQL数据库的方法。分享给大家供大家参考。具体实现方法如下:
import MySQLdb
conn = MySQLdb.connect(host="localhost",
user="root",
passwd="123456",
db="test")
cursor = conn.cursor()
cursor.execute("select * from hard")
res = cursor.fetchall()
for x in res:
print x
cursor.close()
conn.close()
运行结果如下:
希望本文所述对大家的python程序设计有所帮助。