pycharm 使用ORM建立数据库

数据表的建立

表的建立

在models.py文件里面建立数据表类,python

from django.db import models
class userinfo(models.Model):
    uid = models.AutoField(primary_key=True)
    username = models.CharField(max_length=32)
    password = models.CharField(max_length=64)

在终端执行数据库建立命令数据库

python3 manage.py makemigrations
python3 manage.py migrate

pycharm 使用ORM建立数据库

这里须要注意的是,要在setting里面配置上你的程序,以下图
pycharm 使用ORM建立数据库django

执行完成后,能够登陆到数据库中,查看是否有你建立的数据库表
pycharm 使用ORM建立数据库markdown

表的更新

把username 字段修改成user字段,如何操做?session

from django.db import models
class userinfo(models.Model):
    uid = models.AutoField(primary_key=True)
    user = models.CharField(max_length=32)
    password = models.CharField(max_length=64)

执行数据库生成命令,能够看到这里会有提高,询问是否要把那个表下面的那个字段要作调整,这里咱们选择Y,回车操做 继续执行下面的命令:app

C:\Users\Tony\PycharmProjects\LearnDjango>python3 manage.py makemigrations
Did you rename userinfo.username to userinfo.user (a CharField)? [y/N]
C:\Users\Tony\PycharmProjects\LearnDjango>python3 manage.py migrate
Operations to perform:
  Apply all migrations: admin, app01, sessions, auth, contenttypes
Running migrations:
  Rendering model states... DONE
  Applying app01.0002_auto_20180115_1735... OK

能够看到结果是修改了的ide

pycharm 使用ORM建立数据库

添加字段的默认值

若是咱们添加一个字段默认没有给值,则在执行数据库migrations的时候是会有提高,提示结果以下:ui

C:\Users\Tony\PycharmProjects\LearnDjango>python3 manage.py makemigrations
You are trying to add a non-nullable field 'age' to userinfo without a default; we can't do that (the database needs something to populate existing ro
ws).
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
Select an option:

解决方法:
咱们选择2取消这个提示,这个时候,咱们有两种方法解决:
第一种就是设置一个默认值defaultcode

from django.db import models
class userinfo(models.Model):
    uid = models.AutoField(primary_key=True)
    user = models.CharField(max_length=32)
    password = models.CharField(max_length=64)
    age = models.IntegerField(default=1)

第二种解决方法是,指定null能够为空
age = models.IntegerField(null=True)orm

相关文章
相关标签/搜索