python怎么连接mysql数据库

 我来答
爱可生云数据库
2020-10-28 · MySQL开源数据库领先者
爱可生云数据库
爱可生,金融级开源数据库和数据云服务整体解决方案提供商;优秀的开源数据库技术,企业级数据处理技术整体解决方案提供商;私有云数据库云服务市场整体解决方案提供商。
向TA提问
展开全部

在 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 服务端发出响应包,这个包里记录了登录是否成功,如果没有成功也会给出错误信息。

hu3192
2016-07-12 · TA获得超过300个赞
知道小有建树答主
回答量:137
采纳率:75%
帮助的人:50万
展开全部
python2.X 使用 MySQLdb(python3.X 使用 pymysql)

#!/usr/bin/python
# -*- coding: utf-8 -*-
import MySQLdb

#连接数据库
conn= MySQLdb.connect(
        host='localhost',
        port = 8080,
        user='root',
        passwd='123456',
        db ='db_test',
        )
cur = conn.cursor()

#创建数据表
#cur.execute("create table student(id int ,name varchar(20),class varchar(30),age varchar(10))")

#插入一条数据
#cur.execute("insert into student values('2','Tom','3 year 2 class','9')")


#修改查询条件的数据
#cur.execute("update student set class='3 year 1 class' where name = 'Tom'")

#删除查询条件的数据
#cur.execute("delete from student where age='9'")

cur.close()
conn.commit()
conn.close()
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友4e1e372
2016-07-12 · TA获得超过322个赞
知道小有建树答主
回答量:140
采纳率:0%
帮助的人:98.8万
展开全部
# -*-encoding: utf-8 -*-  
import os, string, sys, MySQLdb
# Connect Database  
try:     
    conn = MySQLdb.connect(host='localhost',port=3306, user='Username, passwd='Password', db='testdatabase')  
except Exception, e:  
    print e  
    sys.exit()  
 
# Acquire cursor 
cursor = conn.cursor()  
  
# Create table 
sql = "create table if not exists test1(name varchar(64) primary key, Year int(4))"  
cursor.execute(sql)  
print "Created table testtable!"  
# Close Connection  
cursor.close()  
conn.close()
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式