python的pymysql连接mysql数据库

#!/usr/bin/python3
#coding=utf-8

import pymysql
#连接数据库
db = pymysql.connect( host='数据库地址',
        port=端口号,
        user='数据库用户名',
        password='数据库用户密码',
        database='数据库名',
        charset='utf8')
#创建游标(操作数据库,必须使用游标,相当于指针)
cursor = db.cursor()
#执行删除表
cursor.execute('drop table if exists test')
#建表SQL
sql = """
        CREATE TABLE `test` (
  `id` int(10) NOT NULL AUTO_INCREMENT COMMENT '自动递增,后面指定了AUTO_INCREMENT=1初始值是1',
  `name` varchar(200) DEFAULT NULL COMMENT '默认值空',
  `area_id` int(10) DEFAULT '0' COMMENT '默认值是0',
  `intro` text COMMENT '介绍',
  `status` int(10) DEFAULT '1' COMMENT '默认值为1',
  PRIMARY KEY (`id`),
  KEY `idx_community_status` (`status`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4 COMMENT='测试表'"""
#执行新建表
cursor.execute(sql)
#循环插入表数据
i = 1
while(i <= 5):
    try:
        #执行插入表数据
        cursor.execute("INSERT into test VALUES(%s,'ddd',0,'eess',1)"%i)
        #提交
        db.commit()
    except:
        #报错回滚
        db.rollback()
    i = i + 1

sqlse = 'select * from test'
#执行查询
cursor.execute(sqlse)
#fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据
results = cursor.fetchall()
for i in results:
    #循环输出获取的数据
    print(i)
#关闭游标
cursor.close()
#关闭数据库
db.close()

##一次插入多条数据
import pymysql

#打开数据库连接
db = pymysql.connect(host = 'conn.thinkinpower.net',
                     port = 13306,
                     user = 'root',
                     password = '123456',
                     db = 'platform_admin',
                     charset = 'utf8')
#获取操作游标
cursor = db.cursor()
#创建表
cursor.execute("create table user (id int(10) primary key,name varchar(20))")
data = [
    (1,"aa"),
    (2,"bb")
]
try:
    cursor.executemany("insert into user values (%s,%s)",data)      #executemany可以插入多条记录
    db.commit()     #提交数据
except:
    db.rollback()       #发生错误时回滚

db.close()      #关闭数据库连接

PS:python使用内置的SQLite

import sqlite3
conn = sqlite3.connect("mrsoft.db")
cursor = conn.cursor()
#cursor.execute("create table user (id int(10) primary key,name varchar(20))")
cursor.execute('insert into user(id,name) values ("1","aa")')
cursor.execute('insert into user(id,name) values ("2","bb")')
cursor.execute("select * from user")
print(cursor.fetchone())        #输出一条查询结果
print(cursor.fetchmany(1))      #输出指定数量的查询结果
cursor.execute("select * from user where id >= ?",(2,))         #问号为占位符,可以避免SQL注入
print(cursor.fetchall())        #输出所有查询结果

cursor.close()
conn.close()

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值