1、mysql 以及mysql-workbench安装(MAC-OS)
- mysql下载
- mysql-workbench 下载
2、Django数据库操作
- 配置Django要链接数据库mysql
- 配置链接mysql数据库的信息
- 使用mysql-bench新建 数据库名 为:byte
- 在testdj项目中 新建app(TestModels),如图所示:
- 新建app命令如下:
django-admin startapp TestModel
- 在setting.py中 配置TestModels,这样可以在testdj目录下的直接饮用testModel 模块的内容
- 在TestModel/models.py中编写数据库模型
- 在terminal中执行命令如下:
$ python manage.py migrate # 创建表结构
$ python manage.py makemigrations TestModel # 让 Django 知道我们在我们的模型有一些变更
$ python manage.py migrate TestModel # 创建表结构
- 若成功执行,在mysql中会看到如下图所示内容
- 添加操作
# 1、添加操作
test1 = Test(name='byte')
test1.save()
# return HttpResponse("<p>数据添加成功!</p>")
- 查询操作
# 2、查询操作
response = ""
response1 = ""
# 通过objects这个模型管理器的all()获得所有数据行,相当于SQL中的SELECT * FROM
list = Test.objects.all()
# filter相当于SQL中的WHERE,可设置条件过滤结果
response2 = Test.objects.filter(id=5)
# 获取单个对象
response3 = Test.objects.get(id=5)
# 限制返回的数据 相当于 SQL 中的 OFFSET 0 LIMIT 2;
list1 = Test.objects.order_by('name')[0:2]
# 数据排序
# Test.objects.order_by("id")
# # 上面的方法可以连锁使用
# Test.objects.filter(name="byte").order_by("id")
# 输出所有数据
for var in list1:
response1 += var.name + " "
response = response1
- 更新操作
# # 3.更新修改操作
# test1 = Test.objects.get(id=1)
# test1.name = 'byte-Google-1'
# test1.save()
# 另外一种方式
# Test.objects.filter(id=1).update(name='Google')
# 修改所有的列
# Test.objects.all().update(name='Google')
- 删除操作
# 4.删除操作
# 删除id=1的数据
# test1 = Test.objects.pop(id)
# test1.delete()
# 另外一种方式
# Test.objects.filter(id=1).delete()
# 删除所有数据
# Test.objects.all().delete()