python自学 (四)第四章 操作数据库 【数据编程接口、使用SQLite】

为了能在开学后更好地融入实验室,本人计划用一个月的时间进行python3语言入门,该系列笔记适合已经有一门编程语言基础的朋友参考使用,欢迎同道者前来交流~

使用教材:
1.《python从入门到精通》清华大学出版社;(自带教学视频【二维码形式】)
2.《机器学习》周志华(西瓜书) 清华大学出版社;
3.《python机器学习手册》 [美]Xhris Albon;
4. BiliBili 《和美女老师一起学python》视频。
………………………………

(一)数据库编程接口 connect

数据库种类很多,比如SQLite、MySQL、Oracle……等等,但是它们的基本功能都是一样的,而且为了操作方便,大部分的语言都提供了简单、标准化的数据库接口【API】

1.数据库连接对象
数据库连接对象主要提供获取数据库游标对象和提交事务的方法,以及关闭数据库连接。

获取连接对象的方式 : 使用connect() 函数。

——connect函数参数一览——

参数说明
dsn数据源名称,给出该参数表示数据库依赖
user用户名
password用户密码
host主机名
database数据库名称

在连接数据库的时候,要用到python中的 Pymysql模块,使用方法如下:

import pymysql
conn=pymysql.connect(host='localhost',
                     user='user',
                     password='passwd',
                     db='test',
                     charset='utf8',
                     cursorclass=pymysql.cuirsors.DictCursor)

connect()函数返回的是一个 对象,这个对象代表目前和数据库的会话,这个对象支持的方法如下表所示:

方法名说明
close()关闭数据库连接
commit()提交事务
rollback()回滚事务
cursor()获取游标对象,操作数据库,如执行DML操作,调用存储过程等

………………………………

(二)游标对象 cursor

游标对象主要用于指示花去数据操作的上下文,负责提供执行SQL语句,调用存储过程以及获取查询结果等方法。
1.获取游标对象 :使用cursor方法;
2.游标对象的属性:

description数据库列类型和值的描述信息
rowcount数据库行数统计信息

………………………………

(三)使用SQLite

SQLite不是一个客户端/服务器结构的数据库引擎,而是一个嵌入式数据库,因为它是用C语言编写的,所以SQLite的体量非常小,经常被集成在各种应用中,python中就带有这种内置数据库,不需要安装任何模块就可以直接使用。

3.1 创建数据库文件

1.直接 用Import语句导入SQLite3模块,python操作数据库的流程为:

开始-》 创建connection -> 获取cursor (游标)-> 执行SQL语句,处理结果数据->关闭cursor ->关闭connection -》结束

import sqlite3
#连接到SQLite数据库
conn = wqlite3.connect('mrsoft.db')
#数据库文件是mrsoft.db 如果文件不存在,就会自动在当权目录创建文件
cursor = conn.cursor()
#创建一个cursor
cursor.execute('create table user(id int(10) primary key ,name varchar(20))')
#执行一条SQL语句,创建user表
cursor.close()
#关闭游标
conn.close()
#关闭connection

………………………………

3.2 操作SQLite

1.新增用户信息

当要向数据表中新增数据时,可以使用如下的SQL语句:

insert into 表名(字段名1,字段名2,...,字段名n) values(字段值1,字段值2,...,字段值n)

在user表中有两个字段,字段名分别为id和names。id是一个长度为10的整形,name是一个长度为20的字符串型数据。向user表中插入3条用户信息记录,则SQL语句如下:

cursor.execute('insert into user(id,name) values("1","MRSOFT")')
cursor.execute('insert into user(id,name) values("2","Andy")')
cursor.execute('insert into user(id,name) values("3","明日科技小助手")')

………………………………
2.查看用户数据信息

查看数据库中的用户信息方式为:

select字段名1,字段名2,...,字段名n from  表名 where 查询条件

查询数据时通常使用如下三种方式:

名称用途
fetchone()获取查询结果集中的下一条记录
fetchmany(size)获得指定数量的记录
fetchall()获取结果集的所有记录

使用方式展示:

import sqlite3
conn = sqlite3.connect('mrsoft.db')
cursor = conn.cursor()
cursor.execute('select * from user')

#获取查询结果集中的下一条记录
result1 = cursor.fetchone()
print(result1)

cursor.close()
conn.close()

此时,fetchone 返回的result1是一个元组,运行结果为: (1,‘Mosotf’)

result2 = cursor.fetchmany(2)  #使用fetchmany方法查询多条数据
print ( result2)

如果使用 fetchmany 功能,则返回的result2是一个列表,列表中包含多个元组

[ (1,'mrsoft),(2,‘Andy’)]

fetchall 功能同样是返回一个列表,与fetchmany相近

注意:查询语句还有另一种表达方式:
cursor.execute(‘select * from user where id >?’ , (1 , ))
等同于:
cursor.execute(‘select * from user where id >1’)
使用占位符可以有效避免SQL受到注入攻击的风险。

………………………………
3.修改用户信息

update 表名 set 字段名 = 字段值 where 查询条件

………………………………
4.删除用户信息

delete from 表名 where 查询条件

………………………………

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值