2. 设计数据模型

阅读: 103265     评论:15

使用Django开发Web应用的过程中,很多人都是急急忙忙地写视图,写前端页面,把最根本的模型设计给忽略了。模型中定义了数据如何在数据库内保存,也就是数据表的定义方式。这部分工作体现在Django的代码中,其实就是model类的设计。

一、 数据库模型设计

作为一个用户登录和注册项目,需要保存的都是各种用户的相关信息。很显然,我们至少需要一张用户表User,在用户表里需要保存下面的信息:

  • 用户名
  • 密码
  • 邮箱地址
  • 性别
  • 创建时间

我们现在就暂定保存这些信息吧,更多的内容,请大家在实际项目中自行添加。

进入login/models.py文件,这里将是我们整个login应用中所有模型的存放地点,代码如下:

from django.db import models

# Create your models here.


class User(models.Model):

    gender = (
        ('male', "男"),
        ('female', "女"),
    )

    name = models.CharField(max_length=128, unique=True)
    password = models.CharField(max_length=256)
    email = models.EmailField(unique=True)
    sex = models.CharField(max_length=32, choices=gender, default="男")
    c_time = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.name

    class Meta:
        ordering = ["-c_time"]
        verbose_name = "用户"
        verbose_name_plural = "用户"

各字段含义:

  • name: 必填,最长不超过128个字符,并且唯一,也就是不能有相同姓名;
  • password: 必填,最长不超过256个字符(实际可能不需要这么长);
  • email: 使用Django内置的邮箱类型,并且唯一;
  • sex: 性别,使用了一个choice,只能选择男或者女,默认为男;
  • 使用__str__方法帮助人性化显示对象信息;
  • 元数据里定义用户按创建时间的反序排列,也就是最近的最先显示;

注意:这里的用户名指的是网络上注册的用户名,不要等同于现实中的真实姓名,所以采用了唯一机制。如果是现实中的人名,那是可以重复的,肯定是不能设置unique的。另外关于密码,建议至少128位长度,原因后面解释。

二、 设置数据库后端

定义好了模型后,就必须选择我们用来保存数据的数据库系统。Django支持Mysql,SQLite,Oracle等等。

Django中对数据库的设置在settings文件中,如下部分:

# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

Django默认使用SQLite数据库,并内置SQLite数据库的访问API,也就是说和Python一样原生支持SQLite。本项目使用SQLite作为后端数据库,因此不需要修改settings中这部分内容。如果你想要使用别的数据库,请自行修改该部分设置。

三、注册app

每次创建了新的app后,都需要在全局settings中注册,这样Django才知道你有新的应用上线了。在settings的下面部分添加‘login’,建议在最后添加个逗号。

# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'login',
]

四、创建记录和数据表

app中的models建立好了后,并不会自动地在数据库中生成相应的数据表,需要你手动创建。

进入Pycharm的terminal终端,执行下面的命令:

python manage.py makemigrations

返回结果:

(venv) D:\work\2019\for_test\mysite>python manage.py makemigrations
Migrations for 'login':
  login\migrations\0001_initial.py
    - Create model User

Django自动为我们创建了login\migrations\0001_initial.py文件,保存了我们的第一次数据迁移工作,也就是创建了User模型。

接着执行下面的命令:

python manage.py migrate

Django将在数据库内创建真实的数据表。如果是第一次执行该命令,那么一些内置的框架,比如auth、session等的数据表也将被一同创建,如下所示:

(venv) D:\work\2019\for_test\mysite>python manage.py migrate
Operations to perform:
  Apply all migrations: admin, auth, contenttypes, login, sessions
Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying admin.0002_logentry_remove_auto_add... OK
  Applying admin.0003_logentry_add_action_flag_choices... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying auth.0007_alter_validators_add_error_messages... OK
  Applying auth.0008_alter_user_username_max_length... OK
  Applying auth.0009_alter_user_last_name_max_length... OK
  Applying auth.0010_alter_group_name_max_length... OK
  Applying auth.0011_update_proxy_permissions... OK
  Applying login.0001_initial... OK
  Applying sessions.0001_initial... OK

 1. 搭建项目环境 3. admin后台 

评论总数: 15


点击登录后方可评论

刘老师您好:模型设计,比如说要设置头像这些,是不是在这个模型上加字段呢



是的



这个创建的数据库表名会自动加上“assets_”,请问我如何修改这个规则?另外我如果使用已有的表,如何关联?



请问我在运行python manage.py makemigrations之后提醒django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module. Did you install mysqlclient? 应该怎么解决啊。修改ini文件提示没有pymysql这个model



pip install pymysql http://www.liujiangblog.com/course/django/165



1. pip install mysqlclient 2. pip uninstall pymysql 3. 将__init__.py文件清空



django.db.utils.ProgrammingError: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to us e near '; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED' at line 1") 请问这个增么弄?



是在使用虚拟环境的时候报的这个错误,当不使用虚拟环境的时候就能正常连接,



我这里是Win10环境,mysql数据库,django2.0版本。没有使用虚拟环境运行但是还是出现这个报错,是怎么回事? d:\django_restful2>python manage.py makemigrations api Traceback (most recent call last): File "C:\Python35\lib\site-packages\django\db\backends\utils.py", line 83, in _execute return self.cursor.execute(sql) File "C:\Python35\lib\site-packages\django\db\backends\mysql\base.py", line 71, in execute return self.cursor.execute(query, args) File "C:\Python35\lib\site-packages\pymysql\cursors.py", line 170, in execute result = self._query(query) File "C:\Python35\lib\site-packages\pymysql\cursors.py", line 328, in _query conn.query(q) File "C:\Python35\lib\site-packages\pymysql\connections.py", line 516, in query self._affected_rows = self._read_query_result(unbuffered=unbuffered) File "C:\Python35\lib\site-packages\pymysql\connections.py", line 727, in _read_query_result result.read() File "C:\Python35\lib\site-packages\pymysql\connections.py", line 1066, in read first_packet = self.connection._read_packet() File "C:\Python35\lib\site-packages\pymysql\connections.py", line 683, in _read_packet packet.check_error() File "C:\Python35\lib\site-packages\pymysql\protocol.py", line 220, in check_error err.raise_mysql_exception(self._data) File "C:\Python35\lib\site-packages\pymysql\err.py", line 109, in raise_mysql_exception raise errorclass(errno, errval) pymysql.err.ProgrammingError: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED' at line 1")



没看明白啥意思 第一个字段好像是排序 后面不知道了 求大神详解一下 我是小白



参考这里http://www.liujiangblog.com/course/django/99



博主,你好! 每次创建好模型下边那个def__str__()函数,return self.字段名。请问这个字段名是怎么确定是哪个的?



模型中的任何字段都可以,但尽量选直观的,独一无二的,能区分他者的。



def __str__(self): return self.name 这里用这个好吧?不然linux 下输入中文会报错 def __unicode__(self): return self.name



python2用的是 def __unicode__(self):,python3用的是 def __str__(self):,这个是根据你的python版本写的