Python3进阶篇——sqlite3基础使用_python srlite3(1)

最后

Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

👉Python所有方向的学习路线👈

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

👉Python必备开发工具👈

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

👉Python全套学习视频👈

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

👉实战案例👈

学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。

因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。

👉大厂面试真题👈

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

import sqlite3    # 导入库,这个是python自带的,不需要我们安装

conn = sqlite3.connect('test1.db')    # 连接数据库,如果路径下没有,则创建数据库再打开

conn.close()    # 关闭数据库

我们在上面说了,既然是数据库,那么肯定就有数据表和每张数据表的关键字段,这个就是我们后面数据的添加、处理、删除的依据:

import sqlite3

conn = sqlite3.connect('test1.db')
cursor = conn.cursor()    # 创建一个游标,我们可以把数据库想象成一个工厂,游标就是在工厂工作的工人
                          # 对数据表的任何操作都可以让工人去做,通过游标来实现
# 接下来就是需要执行命令了
cursor.execute('''CREATE TABLE TABLE1            # CREATE TABLE 表名    创建一张数据表
                # 下面就是数据表的关键字段,就是说数据表包含哪些信息
                # 字段名 数据类型 [其他设置]
                (ID INT PRIMARY KEY NOT NULL,
                NAME TEXT NOT NULL,
                AGE INT NOT NULL,
                ADDRESS CHAR(50));''')

conn.commit()    # 提交事务,就相当于提交工作,保存之前的操作
conn.close()     # 关闭数据库连接

我们先来看一下execute()方法,它就是用来执行sql语句的的,里面的参数就是一个字符串,这个字符串就是sql语句;
创建数据表语句:CREATE TABLE 表名(字段名 数据类型)
字段名我们不用讲了,就相当于变量名,指明数据时有什么含义
数据类型:在sqlite里面,有五种数据的存储类:

存储类说明
NULL空值,没有保存数据
INTEGER带符号的整数,会根据数值大小分配1、2、3、4、6或8字节的存储空间
REAL浮点数(分配8个字节的存储空间)
TEXT文本字符串
BLOB二进制文件的容器,可以将二进制图片等存储在这里
没有布尔类型在这里表示逻辑值可用0或1代替
也没有日期类型有三种存储方式,我这边还是以文本存储“YYYY-MM-DD HH:MM:SS.SSS”,分别对应年月日时分秒

但是SQLite支持列的亲和类型,就像攀亲戚,可以使用CHAR(n),定义定长字符串,这也是符合要求的,这边不做赘述,可以看菜鸟教程的SQLite数据类型相关内容了解;
下面把常见的几种亲和数据类型用法总结下,后续不断补充:

数据类型说明
VARCHAR(n)长度不固定,但是最大长度为n的字符串,最大长度不可超过4000
CHAR(n)长度固定为n的字符串,最大长度不可超过254

PRIMARY KEY:主键,首先主键不是数据表的必选项,但是为了数据的完整性、冗余性方面考虑,主键是必要的,主键有着唯一性和非空性的特性,什么意思?

我们以上面基本信息表的栗子来说明:

  1. 如果没有主键的话,只要符合数据类型,都可以添加进去,那么就有一种情况,同一个人的信息添加了两遍,这个添加没有任何错误,但是重复的数据就增加了数据的冗余性,确保每一条数据起码有信息是不一样的;
  2. 那么怎么找主键的关键字呢?那么就要看这个字段的唯一性,就是说这个字段不会出现公用的情况——上面的栗子,“学校”肯定不行,一个学校得有多少学生哈;“班级”也不行,一个班人也很多;“学号”貌似可以,一个班每个学生的学号是不肯能重复的;“姓名”可能会重名啊;其他的就不一一举例了。那么在这里,学号是我们最好的主键字段,当然上面的学号非常简单,正规的应该班级+序号,或者入学年份+班级+序号。

还有一个外键,这个就是用来对两张数据表建立联系的,这里先不讲,后面再说;

NOT NULL:其实也非常简单,字面意思就是非空,表明这个字段不能为空;

好了,现在我们的数据表已经建好了(注意,当我们数据表建好之后,不能再创建同名的表,也就是说CREATE TABLE 表名 只能执行一次,如果想添加或删除字段,那么可以用ALTER语句实现,这个也是后面再讲)接下来我们就要插入数据了:

import sqlite3

conn = sqlite3.connect('test1.db')
cursor = conn.cursor()

cursor.execute('INSERT INTO TABLE1 VALUES (2,"TEST",13,"HEN")')

conn.commit()
conn.close()

INSERT INTO 表名 [字段名] VALUES (值):是往数据表中插入值的SQL语句,字段名可以省略,但是后面的值就要与表中所有的字段一一对应,如果只是想插入表中的若干字段,那么可以指明字段名,然后设置值;

我们已经将一条字段信息添加到数据库里面去了,我们可以安装SQLite打开文件,但是这比较麻烦,我们可以用SQLiteSpy查看我们的数据库(云盘链接已附上,提取码:lcmw)

接下来我们我们多添加几条信息进去,来看看查询语句怎么使用:

import sqlite3

conn = sqlite3.connect('test1.db')
cursor = conn.cursor()

# data = cursor.execute('SELECT ID,NAME,AGE,ADDRESS FROM TABLE1')
# 两种写法的效果是一样的,上面选择提取的字段,下面则表示所有的字段
data = cursor.execute('SELECT * FROM TABLE1')
print(list(data))

conn.commit()
conn.close()

# 输出结果:
# [(2, 'TEST', 13, 'HEN'), (1, 'TEST1', 13, 'HEN1'), (3, 'TEST3', 3, 'HEN3'), (4, 'TEST4', 4, 'HEN4'), (5, 'TEST5', 5, 'HEN5'), (6, 'TEST6', 6, 'HEN6'), (7, 'TEST7', 7, 'HEN7'), (8, 'TEST8', 8, 'HEN8'), (9, 'TEST9', 9, 'HEN9'), (10, 'TEST10', 10, 'HEN10'), (11, 'TEST11', 11, 'HEN11'), (12, 'TEST12', 12, 'HEN12'), (13, 'TEST13', 13, 'HEN13'), (14, 'TEST14', 14, 'HEN14'), (15, 'TEST15', 15, 'HEN15'), (16, 'TEST16', 16, 'HEN16'), (17, 'TEST17', 17, 'HEN17'), (18, 'TEST18', 18, 'HEN18'), (19, 'TEST19', 19, 'HEN19')]

SELECT 字段名 FROM 表名:这个就是查找语句,会把所有符合要求的字段都返回,注意:结果是以元组的形式返回的;
那么这只是把特定的字段选择提取出来了而已,有时候我需要指定条件,比如AGE<10的学生信息显示出来,那么需要怎么处理呢?

import sqlite3

conn = sqlite3.connect('test1.db')
cursor = conn.cursor()

data = cursor.execute('SELECT * FROM TABLE1 WHERE AGE<10')
print(list(data))

conn.commit()
conn.close()

# 输出结果:
# [(3, 'TEST3', 3, 'HEN3'), (4, 'TEST4', 4, 'HEN4'), (5, 'TEST5', 5, 'HEN5'), (6, 'TEST6', 6, 'HEN6'), (7, 'TEST7', 7, 'HEN7'), (8, 'TEST8', 8, 'HEN8'), (9, 'TEST9', 9, 'HEN9')]

这时候我们就可以用WHERE子句,来限制我们的条件:SELECT 字段名 FROM 表名 WHERE 条件表达式

data = cursor.execute('SELECT * FROM TABLE1 WHERE AGE<10 AND ID<5')    # 取两个条件的交集
data = cursor.execute('SELECT * FROM TABLE1 WHERE AGE=13 OR ID<10')    # 取两个条件的并集
data = cursor.execute('SELECT * FROM TABLE1 WHERE NOT(AGE=13)')        # 条件置反,即除了……

如果我们想修改某个字段的值,那么我们可以用UPDATE语句进行字段的修改:
UPDATE 表名 SET 字段名=值 WHERE 表达式,如果想把所有的AGE都改为14,那么不用设置条件就好了;

import sqlite3

conn = sqlite3.connect('test1.db')
cursor = conn.cursor()


**一、Python所有方向的学习路线**

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

![img](https://img-blog.csdnimg.cn/1d40facda2b84990b8e1743f5487d455.png)  
![img](https://img-blog.csdnimg.cn/0fc11d4a31bd431dbf124f67f1749046.png)

**二、Python必备开发工具**

工具都帮大家整理好了,安装就可直接上手!![img](https://img-blog.csdnimg.cn/ff266f529c6a46c4bc28e5f895dec647.gif#pic_center)

**三、最新Python学习笔记**

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

![img](https://img-blog.csdnimg.cn/6d414e9f494742db8bcc3fa312200539.png)

**四、Python视频合集**

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

![img](https://img-blog.csdnimg.cn/a806d9b941c645858c61d161aec43789.png)

**五、实战案例**

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。![img](https://img-blog.csdnimg.cn/a353983317b14d3c8856824a0d6186c1.png)

**六、面试宝典**

![在这里插入图片描述](https://img-blog.csdnimg.cn/97c454a3e5b4439b8600b50011cc8fe4.png)

![在这里插入图片描述](https://img-blog.csdnimg.cn/111f5462e7df433b981dc2430bb9ad39.png)

###### **简历模板**![在这里插入图片描述](https://img-blog.csdnimg.cn/646863996ac44da8af500c049bb72fbd.png#pic_center)




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618317507)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值