网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
- 首先他是一个文档
这个文档里面存放了很多东西,我们将它的后缀改成 .zip,就是压缩文件格式,再把它打开,我们看下里面有什么:
我们发现里面不仅有我们存入的数据,还有像.xml这样表示前端的文件,一个Excel文件保存的数据是非常多的;再举个栗子,我们有时候会对Excel文档进行加密,要是密码忘记了,就可以通过这里删除密码; - 我们打开Excel文档,看看里面有什么:
我们打开文档之后,看到的是一张数据表,中间的就是数据表的内容,可以创建多张表,每张表格可以命名可以表示文档的名字;我们可以在第一行键入数据的说明,然后在第二行还是键入数据,这样就构成了一张我们简单的数据表:
- 我们不仅能够保存数据,还可以通过excel对数据进行查找和处理,比如计算语文成绩的平均分、对多门成绩进行排名、搜索小明的信息等等:
- 这是单张表格的操作,我们还可以对同个文档的多个数据表进行数据交互,甚至多个文档的多个数据表进行交互:
- 那么既然数数据,那肯定就有数据类型,有不同的功能:
ok,那么相信通过Excel文档,大家对数据表有了一个简单的了解,那么数据库就像这个excel文档一样,它首先是一个文件,里面保存了我们需要存储的数据,但是它的体积很小,没有.xml这些前端的数据;他的组织也是以数据表为单位,每张表格都会定义关键字段,就像学校、年级这些;通过找到指定的表格,指定的字段,通过插入、搜索、删除等操作,对数据进行处理;通过外键可以和其他的数据表之间数据互通,减少数据的冗余(就是说重复的数据)。我们暂且可以把数据库理解成excel,但是数据库更简洁、更高效;
下面我们来看一下,怎么来创建一个数据库:
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:主键,首先主键不是数据表的必选项,但是为了数据的完整性、冗余性方面考虑,主键是必要的,主键有着唯一性和非空性的特性,什么意思?
我们以上面基本信息表的栗子来说明:
- 如果没有主键的话,只要符合数据类型,都可以添加进去,那么就有一种情况,同一个人的信息添加了两遍,这个添加没有任何错误,但是重复的数据就增加了数据的冗余性,确保每一条数据起码有信息是不一样的;
- 那么怎么找主键的关键字呢?那么就要看这个字段的唯一性,就是说这个字段不会出现公用的情况——上面的栗子,“学校”肯定不行,一个学校得有多少学生哈;“班级”也不行,一个班人也很多;“学号”貌似可以,一个班每个学生的学号是不肯能重复的;“姓名”可能会重名啊;其他的就不一一举例了。那么在这里,学号是我们最好的主键字段,当然上面的学号非常简单,正规的应该班级+序号,或者入学年份+班级+序号。
还有一个外键,这个就是用来对两张数据表建立联系的,这里先不讲,后面再说;
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')]
### 最后
不知道你们用的什么环境,我一般都是用的Python3.6环境和pycharm解释器,没有软件,或者没有资料,没人解答问题,都可以免费领取(包括今天的代码),过几天我还会做个视频教程出来,有需要也可以领取~
给大家准备的学习资料包括但不限于:
Python 环境、pycharm编辑器/永久激活/翻译插件
python 零基础视频教程
Python 界面开发实战教程
Python 爬虫实战教程
Python 数据分析实战教程
python 游戏开发实战教程
Python 电子书100本
Python 学习路线规划
![](https://img-blog.csdnimg.cn/d29631674929476f9c3b30f7ff58dff0.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2ZlaTM0Nzc5NTc5MA==,size_16,color_FFFFFF,t_70)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618317507)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**