Django 模型(数据库)-cmd下的操作
Django 模型是与数据库相关的,与数据库相关的代码一般写在 models.py 中,Django 支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在settings.py中配置即可,不用更改models.py中的代码,丰富的API极大的方便了使用。
1. 新建项目和应用
- python manage.py startapp TestModel
# 新建一个项目
- (venv)...> python manage.py migrate # 创建表结构
- (venv)...> python manage.py makemigrations TestModel # 让 Django 知道我们在我们的模型有一些变更
- (venv)...> python manage.py migrate TestModel # 创建表结构
- 定义模型(models)->激活模型(setting)
HelloWorld/TestModel/models.py: 文件代码:
- # models.py
- from django.db import models
- class Test(models.Model):
- name = models.CharField(max_length=20)
- 文件目录:
- HelloWorld
- |-- HelloWorld
- |-- manage.py
- ...
- |-- TestModel
- | |-- __init__.py
- | |-- admin.py
- | |-- models.py
- | |-- tests.py
- | `-- views.py
2. 添加应用
将我们新建的应用(people)添加到 settings.py 中的 INSTALLED_APPS中,也就是告诉Django有这么一个应用。
- INSTALLED_APPS = [
- 'django.contrib.admin',
- 'django.contrib.auth',
- 'django.contrib.contenttypes',
- 'django.contrib.sessions',
- 'django.contrib.messages',
- 'django.contrib.staticfiles',
- 'TestModel',
- ]
3. 数据库操作(修改models.py)
接下来我们在 HelloWorld 目录中添加 testdb.py 文件(下面介绍),并修改 urls.py:
- HelloWorld/HelloWorld/urls.py: 文件代码:
- from django.urls import path
- from . import views,testdb
- urlpatterns = [
- path('runoob/', views.runoob),
- path('testdb/', testdb.testdb),
- ]
4、添加数据
- HelloWorld/HelloWorld/testdb.py: 文件代码:
# -*- coding: utf-8 -*-- from django.http import HttpResponse
- from TestModel.models import Test
- # 数据库操作
- def testdb(request):
- test1 = Test(name='runoob')
- test1.save()
- return HttpResponse("<p>数据添加成功!</p>")
5、获取数据
HelloWorld/HelloWorld/testdb.py: 文件代码:
- # -*- coding: utf-8 -*-
- from django.http import HttpResponse
- from TestModel.models import Test
- # 数据库操作
- def testdb(request):
- # 初始化
- response = ""
- response1 = ""
- # 通过objects这个模型管理器的all()获得所有数据行,相当于SQL中的SELECT * FROM
- list = Test.objects.all()
- # filter相当于SQL中的WHERE,可设置条件过滤结果
- response2 = Test.objects.filter(id=1)
- # 获取单个对象
- response3 = Test.objects.get(id=1)
- # 限制返回的数据 相当于 SQL 中的 OFFSET 0 LIMIT 2;
- Test.objects.order_by('name')[0:2]
- #数据排序
- Test.objects.order_by("id")
- # 上面的方法可以连锁使用
- Test.objects.filter(name="runoob").order_by("id")
- # 输出所有数据
- for var in list:
- response1 += var.name + " "
- response = response1
- return HttpResponse("<p>" + response + "</p>")
6、更新数据
- HelloWorld/HelloWorld/testdb.py: 文件代码:
- # -*- coding: utf-8 -*-
- from django.http import HttpResponse
- from TestModel.models import Test
- # 数据库操作
- def testdb(request):
- # 修改其中一个id=1的name字段,再save,相当于SQL中的UPDATE
- test1 = Test.objects.get(id=1)
- test1.name = 'Google'
- test1.save()
- # 另外一种方式
- #Test.objects.filter(id=1).update(name='Google')
- # 修改所有的列
- # Test.objects.all().update(name='Google')
- return HttpResponse("<p>修改成功</p>")
7、删除数据
- HelloWorld/HelloWorld/testdb.py: 文件代码:
- # -*- coding: utf-8 -*-
- from django.http import HttpResponse
- from TestModel.models import Test
- # 数据库操作
- def testdb(request):
- # 删除id=1的数据
- test1 = Test.objects.get(id=1)
- test1.delete()
- # 另外一种方式
- # Test.objects.filter(id=1).delete()
- # 删除所有数据
- # Test.objects.all().delete()
- return HttpResponse("<p>删除成功</p>")
新建一个对象的方法有以下几种:
Person.objects.create(name=name,age=age)
p = Person(name="WZ", age=23)
p.save()
p = Person(name="TWZ")
p.age = 23
p.save()
Person.objects.get_or_create(name="WZT", age=23)
这种方法是防止重复很好的方法,但是速度要相对慢些,返回一个元组,第一个为Person对象,第二个为True或False, 新建时返回的是True, 已经存在时返回False.
获取对象有以下方法:
Person.objects.all()
Person.objects.all()[:10] 切片操作,获取10个人,不支持负索引,切片可以节约内存
Person.objects.get(name=name)
get是用来获取一个对象的,如果需要获取满足条件的一些人,就要用到filter
Person.objects.filter(name="abc") # 等于Person.objects.filter(name__exact="abc") 名称严格等于 "abc" 的人
Person.objects.filter(name__iexact="abc") # 名称为 abc 但是不区分大小写,可以找到 ABC, Abc, aBC,这些都符合条件
Person.objects.filter(name__contains="abc") # 名称中包含 "abc"的人
Person.objects.filter(name__icontains="abc") #名称中包含 "abc",且abc不区分大小写
Person.objects.filter(name__regex="^abc") # 正则表达式查询
Person.objects.filter(name__iregex="^abc") # 正则表达式不区分大小写
filter是找出满足条件的,当然也有排除符合某条件的
Person.objects.exclude(name__contains="WZ") # 排除包含 WZ 的Person对象
Person.objects.filter(name__contains="abc").exclude(age=23) # 找出名称含有abc, 但是排除年龄是23岁的
常见报错信息
如果执行以上命令时会出现如下报错信息:
原因是 MySQLclient 目前只支持到 Python3.4,因此如果使用的更高版本的 python,需要修改如下:
通过报错信息的文件路径找到 ...site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 这个路径里的 base.py 文件,把这两行代码注释掉(代码在文件开头部分):
- if version < (1, 3, 13):
- raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)
一般点报错的代码文件路径信息,会自动跳转到报错文件中行数,此时我们在报错的代码行数注释掉。
如果出现以下报错信息:
我们点报错的代码文件路径,跳转到报错文件中行数,此时我们在报错的代码行数之前加上:
- query = query.encode()
Django 模型(数据库)-cmd下的操作的更多相关文章
- {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ...
- Django模型层之单表操作
Django模型层之单表操作 一 .ORM简介 我们在使用Django框架开发web应用的过程中,不可避免地会涉及到数据的管理操作(如增.删.改.查),而一旦谈到数据的管理操作,就需要用到数据库管理软 ...
- day 70 Django基础五之django模型层(二)多表操作
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...
- day 69 Django基础五之django模型层(一)单表操作
Django基础五之django模型层(一)单表操作 本节目录 一 ORM简介 二 单表操作 三 章节作业 四 xxx 一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现 ...
- day 56 Django基础五之django模型层(二)多表操作
Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 ORM ...
- day 55 Django基础五之django模型层(一)单表操作
Django基础五之django模型层(一)单表操作 本节目录 一 ORM简介 二 单表操作 三 章节作业 四 xxx 一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它 ...
- Django模型-数据库操作
前言 前边记录的URLconf和Django模板全都是介绍页面展示的东西,也就是表现层的内容.由于Python先天具备简单而强大的数据库查询执行方法,Django 非常适合开发数据库驱动网站. 这篇开 ...
- django模型——数据库(二)
模型--数据库(二) 实验简介 模型的一些基本操作,save方法用于把对象写入到数据库,objects是模型的管理器,可以使用它的delete.filter.all.order_by和update等函 ...
- CMD下文件操作
CMD下常用文件操作指令 1.输入盘符 如C: 然后回车,相当于进了C盘(c盘一般进的是桌面目录) 2.输入 cd 目录名 然后回车(目录名是c盘中的一级目录名,也可为c盘中的目录路径).如cd mm ...
随机推荐
- ceph如何快速卸载所有osd及擦除磁盘分区表和内容并重新加入
我的ceph集群中有4台服务器,16个osd,因为某些原因,集群中的数据都不要了,但是集群要保留给新的应用使用,集群现有的osd情况如下 [root@ceph-host-01 ~]# cat /etc ...
- ADF 第七篇:控制流
Azure Data Factory 系列博客: ADF 第一篇:Azure Data Factory介绍 ADF 第二篇:使用UI创建数据工厂 ADF 第三篇:Integration runtime ...
- 编程漫谈(二十):如何自学编程及Java、上手真实开发及转行程序员的建议
前路漫漫,吾将上下而求索! 最近有时在知乎上逛逛,发现很多人对自学编程及转行程序员有困惑.我是在25岁读研时转程序员,正赶上好时候(中国云计算刚刚起步及移动互联网正红的阶段),同时又走了不少弯路,因此 ...
- Linux中的System V信号量
在进程同步,并发运行时,保证按序地访问共享资源是十分重要的.因此引入了临界区的概念,一次只能有一个线程进入临界区完成他的指令.而信号量(semaphore)的作用,类似于一个交通信号灯,它负责进程协作 ...
- 使用 CoreDNS 来应对 DNS 污染
原文链接:https://fuckcloudnative.io/posts/install-coredns-on-macos/ CoreDNS 是 Golang 编写的一个插件式 DNS 服务器,是 ...
- 输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)
package leetcode;import edu.princeton.cs.algs4.Cycle;import java.util.ArrayList;import java.util.Arr ...
- 使用ajax请求上传多个或者多个附件
jsp页面 <%@ page language="java" pageEncoding="UTF-8"%> <!DOCTYPE HTML> ...
- Maven中使用JSTL
在pom.xml文件下面增加如下的依赖包: <dependency> <groupId>jstl</groupId> <artifactId>jstl& ...
- Hadoop集群模式安装出现的若干问题
一.域名解析问题 域名解析暂时失败问题 vim /etc/sysconfig/network 查看主机名 vim etc/hosts 配置IP地址与主机名 192.168.60.132 centos ...
- Redis原理知识点集锦
1.Redis有哪些数据结构? 字符串String.字典Hash.列表List.集合Set.有序集合SortedSet. 高级数据结构 HyperLogLog:基数统计 GEO:地理位置 PUB/SU ...