zoukankan      html  css  js  c++  java
  • Connector for Python

    MySQL 是最流行的关系型数据库管理系统,如果你不熟悉 MySQL,可以阅读 MySQL 教程。

    下面为大家介绍使用 mysql-connector 来连接使用 MySQL, mysql-connector 是 MySQL 官方提供的驱动器。

    我们可以使用 pip 命令来安装 mysql-connector

    python -m pip install mysql-connector

    使用以下代码测试 mysql-connector 是否安装成功:

    import mysql.connector

    执行以上代码,如果没有产生错误,表明安装成功。

    1、数据库连接

    连接数据库的代码如下

     代码如下 复制代码
    import mysql.connector
    config={'host':'127.0.0.1',#默认127.0.0.1
            'user':'root',
            'password':'123456',
            'port':3306 ,#默认即为3306
            'database':'test',
            'charset':'utf8'#默认即为utf8
            }
    try:
      cnn=mysql.connector.connect(**config)
    except mysql.connector.Error as e:
      print('connect fails!{}'.format(e))

    连接方法上和MySQLdb模块略有不同。MySQLdb使用的是=号,这里使用的是 : 号。

    2、创建表

    下面我们根据上面新建的一个数据库连接创建一张名为student的表:

     代码如下 复制代码
    sql_create_table='CREATE TABLE `student` \
    (`id` int(10) NOT NULL AUTO_INCREMENT,\
    `name` varchar(10) DEFAULT NULL,\
    `age` int(3) DEFAULT NULL,\
    PRIMARY KEY (`id`)) \
    ENGINE=MyISAM DEFAULT CHARSET=utf8'
    cursor=cnn.cursor()
    try:
      cursor.execute(sql_create_table)
    except mysql.connector.Error as e:
      print('create table orange fails!{}'.format(e)) 

    3、插入数据

    插入数据的语法上和MySQLdb上基本上是一样的:

     代码如下 复制代码
    cursor=cnn.cursor()
    try:
      '第一种:直接字符串插入方式'
      sql_insert1="insert into student (name, age) values ('orange', 20)"
      cursor.execute(sql_insert1)
      '第二种:元组连接插入方式'
      sql_insert2="insert into student (name, age) values (%s, %s)"
      #此处的%s为占位符,而不是格式化字符串,所以age用%s
      data=('shiki',25)
      cursor.execute(sql_insert2,data)
      '第三种:字典连接插入方式'
      sql_insert3="insert into student (name, age) values (%(name)s, %(age)s)"
      data={'name':'mumu','age':30}
      cursor.execute(sql_insert3,data)
      #如果数据库引擎为Innodb,执行完成后需执行cnn.commit()进行事务提交
    except mysql.connector.Error as e:
      print('insert datas error!{}'.format(e))
    finally:
      cursor.close()
      cnn.close()

    同样,MySQL Connector也支持多次插入,同样其使用的也是cursor.executemany,示例如下:

     代码如下 复制代码
    stmt='insert into student (name, age) values (%s,%s)'
    data=[
         ('Lucy',21),
         ('Tom',22),
         ('Lily',21)]
    cursor.executemany(stmt,data)

    4、查询操作

     代码如下 复制代码
    cursor=cnn.cursor()
    try:
      sql_query='select id,name from student where  age > %s'
      cursor.execute(sql_query,(21,))
      for id,name in cursor:
        print ('%s\'s age is older than 25,and her/his id is %d'%(name,id))
    except mysql.connector.Error as e:
      print('query error!{}'.format(e))
    finally:
      cursor.close()
      cnn.close()

    5、删除操作

     代码如下 复制代码

    cursor=cnn.cursor()
    try:
      sql_delete='delete from student where name = %(name)s and age < %(age)s'
      data={'name':'orange','age':24}
      cursor.execute(sql_delete,data)
    except mysql.connector.Error as e:
      print('delete error!{}'.format(e))
    finally:
      cursor.close()
      cnn.close()

  • 相关阅读:
    本地服务器能ping通,但是ssh及各种端口都访问不到---待整理
    查看端口
    【服务器防护】linux 如何查看防火墙是否开启
    linux查看与开启sshd服务
    Win7没有telnet怎么办
    oracle Database link 创建
    本地PC安装Centos 6.5 操作手册及遇到的问题
    ORA-28000账户被锁和解锁
    mysql update常见实例
    Java的Statement、PreparedStatement、PreparedStatement + 批处理 的区别
  • 原文地址:https://www.cnblogs.com/wpj593780933/p/10679325.html
Copyright © 2011-2022 走看看