1、新建APP
python manage.py srartapp appname #创建APP应用
2、settings设置
设置时区和语言
Django默认使用美国时间和英语,在项目的settings文件中,如下所示:
# Internationalization
# https://docs.djangoproject.com/en/1.11/topics/i18n/
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
我们把它改为亚洲/上海
时间和中文,注意USE_TZ 改成False了。
# Internationalization
# https://docs.djangoproject.com/en/1.11/topics/i18n/
LANGUAGE_CODE = 'zh-hans' # 这里修改了
TIME_ZONE = 'Asia/Shanghai' # 这里修改了
USE_I18N = True
USE_L10N = True
USE_TZ = False # 这里修改了
在INSTALLED_APPS中添加appname:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
# 'myapp.apps.MyappConfig',
'myapp', #添加APP
]
设置数据库连接:
DATABASES = {
'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
'ENGINE': 'django.db.backends.mysql',
'NAME':'mysql',
'USER':'root',
'PASSWORD':'password.',
'HOST':'localhost',
'PORT':'3306',
}
必须设置__init__.py内容:否则报错: No module named 'PyMySQL'
import pymysql
pymysql.install_as_MySQLdb()
3、修改models.py
from django.db import models
from django.db import models #引入模块
# Create your models here.
class Users(models.Model):
iid=models.IntegerField() #int数据类型
name=models.CharField(max_length=50) #string数据类型
age=models.IntegerField()
b_name=models.CharField(max_length=50)
iphone=models.CharField(max_length=11)
card=models.CharField(max_length=18)
email=models.EmailField() #email数据类型
create_time=models.DateTimeField() #时间数据类型
def __str__(self): #内置函数,初始化执行
return self.name+"生产完毕"
class Deptment(models.Model):
iid=models.IntegerField()
dept_name=models.CharField(max_length=20)
manager_id=models.IntegerField()
create_time=models.DateTimeField()
def __str__(self):
return self.dept_name
4、同步数据库、执行数据库
python manage.py makemigrations #同步数据库
python manage.py migrate #执行数据库
备注:数据库只执行后,数据库创建名为:appname_类名 的数据库表
如果执行异常,需要同时删除二个地方的内容,在同步、重新执行操做:
1、删除app下migrations中所有的内容
2、删除数据库django_migrations中相关该app所有数据行
摘要: 执行manage.py migrate解决报错: django.db.utils.OperationalError: (1050, "Table '表名' already exists)解决方法:
python manage.py migrate myapp --fake
修改models.py数据库:
对 models.py 进行了更改,这些字段数据库中还没有,我们要同步更改到数据库中去:
python manage.py makemigrations
You are trying to add a non-nullable field 'pub_date' to article without a default; we can't do that (the database needs something to populate existing rows).
Please select a fix:
1) Provide a one-off default now (will be set on all existing rows)
2) Quit, and let me add a default in models.py
选择1,设置默认值;
或者在定义models.py类时定义属性
default='' 设置默认值,null=Ture--允许为null,blank=True--允许为空白
python manage.py migrate
5、DJango API
5.1 创建对象:
#方式一:
APP.objects.create(name=name,age=age)
#方式二:
p=APP(name=name,age=age)
p.save()
#方式三:
p=APP(name=name)
p.age=age
p.save()
#方式四:这种方法是防止重复很好的方法,但是速度要相对慢些,返回一个元组,第一个为Person对象,第二个为True或False, 新建时返回的是True, 已经存在时返回False.
APP.objects.get_or_create(name=name,age=age)
备注:前三种方法返回的都是对应的 object。最后一种方法返回的是一个元组,(object, True/False),创建时返回 True, 已经存在时返回 False,获取对象使用[0]
5.2 获取对象
#get是用来获取一个对象的,如果需要获取满足条件的一些人,就要用到filter
#方式一:
APP.objects.all()
#方式二(切片不接受负索引):
APP.objects.all()[0:10]
#方式三:
APP.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岁的
5.3 删除符合条件的结果
Person.objects.filter(name__contains="abc").delete() # 删除 名称中包含 "abc"的人
#如果写成
people = Person.objects.filter(name__contains="abc")
people.delete()
#效果也是一样的,Django实际只执行一条 SQL 语句。
5.4 更新内容
#(1) 批量更新,适用于 .all() .filter() .exclude() 等后面 (危险操作,正式场合操作务必谨慎)
Person.objects.filter(name__contains="abc").update(name='xxx') # 名称中包含 "abc"的人 都改成 xxx
Person.objects.all().delete() # 删除所有 Person 记录
#(2) 单个 object 更新,适合于 .get(), get_or_create(), update_or_create() 等得到的 obj,和新建很类似。
twz = Author.objects.get(name="WeizhongTu")
twz.name="WeizhongTu"
twz.email="tuweizhong@163.com"
twz.save() # 最后不要忘了保存!!!
5.5 迭代遍历
es = Entry.objects.all()
for e in es:
print(e.headline)
Entry.objects.all() 或者 es 就是 QuerySet 是查询所有的 Entry 条目。
注意事项:
(1). 如果只是检查 Entry 中是否有对象,应该用 Entry.objects.all().exists()
(2). QuerySet 支持切片 Entry.objects.all()[:10] 取出10条,可以节省内存
(3). 用 len(es) 可以得到Entry的数量,但是推荐用 Entry.objects.count()来查询数量,后者用的是SQL:SELECT COUNT(*)
(4). list(es) 可以强行将 QuerySet 变成 列表
5.6 查询结果排序
Author.objects.all().order_by('name')
Author.objects.all().order_by('-name') # 在 column name 前加一个负号,可以实现倒序
5.7 链式查询
Author.objects.filter(name__contains="WeizhongTu").filter(email="tuweizhong@163.com")
Author.objects.filter(name__contains="Wei").exclude(email="tuweizhong@163.com")
# 找出名称含有abc, 但是排除年龄是23岁的
Person.objects.filter(name__contains="abc").exclude(age=23)
5.8 QuerySet 重复的问题,使用 .distinct() 去重
#使用.distinct()去重复,只留一条
data = App.objects.filter(name='x').distinct()