Django是一种Python的Web开发框架,今天介绍一下数据库操作.
这里采用sqlite3作为数据库软件,因为它配置起来省事轻量,好用.
- 构建:
我们首先要在App的models.py中写入数据库的定义,但我要讲的不是这些,所以请所有不知道的人自己百度,谢谢大家的配合.
代码写完之后,执行命令:
python manage.py makemigrations
python manage.py migrate
如果在执行第一条命令时出现问题且你不是第一次执行这两条命令,可能是因为你已经生成出的数据.以删除api文件夹下所有形如xxxx_initial.py的文件.
如果在执行第二条命令时出现问题,可能是因为你的数据库已经存在相应的表,只是你更改了字段后重新生成,这时你可以将数据库中的表全部删掉(如果里面的数据重要的话注意保存).然后重新操作即可.
让我们以这个表为示例:
Stu:
id | name | age | className |
---|---|---|---|
1 | 小明 | 10 | 1 |
2 | 小华 | 11 | 2 |
3 | 小刚 | 9 | 3 |
4 | 小马虎 | 12 | 2 |
代码:
class Stu
id=models.AutoField(primary_key=True)
name=models.CharField(max_length=5)
age=models.IntegerField()
className=models.IntegerField
2.创建对象
极简方式:
Stu.objects.create(name="小明",age=10,className=1)
稍微麻烦那么一点点的方式:
stu=Stu(name="小明",age=10,className=1)
stu.save()
再麻烦一点的方式:
stu=Stu()
stu.name="小明"
stu.age=10
stu.className=1
stu.save()
当然我们还可以直接用django提供的cursor实现,但我打算之后再讲.
2.get
函数格式:Model.objects.get(...)
示例:
s1=Stu.objects.get(id=2) #小华
s2=Stu.objects.get(age=10) #小明
s3=Stu.objects.get(className=2) #报错,查到不止一个数据
s4=Stu.objects.get(id=5) #报错,查不到数据
get中使用关键字参数的传递方法(不要问我什么是关键字参数的传递方法,有问题请自行购买并阅读,《Python语言从入门到精通》)限定条件,如果查不到或查到很多会报错哦,建议在里面使用主键进行查找.返回一个Model的实例.
3.filter
函数格式:Model.objects.filter(...)
参数:同样适用关键字参数传递方法,可以有多条数据满足条件.如果不填,可以直接返回所有结果,但没有这个必要,因为你可以使用另一个all函数来实现.
返回值:QuerySet
QuerySet的方法和技巧
首先,你可以使用list将其转换为标准列表,但会损失一些额外的方法.
stus=list(Stu.objects.filter())
因为很多操作都是在这种查询对象上的,所以介绍一下这个queryset
你可以使用len获取长度length=len(Stu.objects.filter()).
它也是一个可迭代对象.
对象方法则有
stus=Stu.objects.filter(className=2)
stus.first #第一个数据
stus.last #最后一个数据
stus.order_by #按字段排序
stus.exits #判断某条数据是否存在
stus.values #获取查询到结果中一列的值
如果你竟然直接进行了这类操作
s=stus.first
别怪我没在上面写这是对象方法.
接下来,让我们介绍一下装逼底层的玩法:直接使用装逼的SQL语句完成所有操作.这种方式不依赖model,但你要引入另一个模块
from django.db import connection
然后,进行这样的操作:
connection.cursor().execute(command:str)
#command:SQL命令
#返回值:一个cursor对象
其中,cursor有还其他一些常用的函数:
close():关闭此游标对象
fetchone():得到结`果集的下一行
fetchmany():得到结果集的下几行
参数:不传等于fetchall,否则传入要得到的行数.
fetchall():得到结果集中剩下的所有行
以上是这篇文章的全部,错误的地方恳请指正.
都看到这了,赞赏一下呗(^ ~ ^ ||).