pycharm 使用ORM创建数据库

简介:

数据表的创建

表的创建

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

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创建数据库

执行完成后,可以登录到数据库中,查看是否有你创建的数据库表
pycharm 使用ORM创建数据库

表的更新

把username 字段修改为user字段,如何操作?

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,回车操作 继续执行下面的命令:

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

可以看到结果是修改了的

pycharm 使用ORM创建数据库

添加字段的默认值

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

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取消这个提示,这个时候,我们有两种方法解决:
第一种就是设置一个默认值default

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)



本文转自 kesungang 51CTO博客,原文链接:http://blog.51cto.com/sgk2011/2061207,如需转载请自行联系原作者

相关文章
|
关系型数据库 数据库 Python
|
2月前
|
API 数据库 Docker
PyCharm 2022.2 发布了,支持最新 Python 3.11 和 PyScript 框架!
PyCharm 2022.2 发布了,支持最新 Python 3.11 和 PyScript 框架!
51 2
|
6月前
|
Python
python安装教程(pycharm安装 汉化)
python安装教程(pycharm安装 汉化)
886 0
|
4月前
|
存储 计算机视觉 Python
搭建Python-OpenCV开发环境(包括Python、Pycharm、OpenCV下载 图文解释)
搭建Python-OpenCV开发环境(包括Python、Pycharm、OpenCV下载 图文解释)
47 0
|
4月前
|
Ubuntu Python
Python(六)使用pycharm创建项目报错:ModuleNotFoundError No module named distutils.util
在ubuntu上使用pycharm创建项目的时候报错: ModuleNotFoundError: No module named 'distutils.util'
606 0
|
5月前
|
开发工具 Python
Python 开发工具 Pycharm —— 使用技巧Lv.2
例子2:方法内使用#号注释,pydoc不会显示注释内容(class同理)
43 0
|
2月前
|
程序员 编译器 C语言
Python基础语法(内置Python, pycharm配置方式)
Python基础语法(内置Python, pycharm配置方式)
|
7月前
|
开发工具 Python Windows
Python及PyCharm安装教程【图文教程】
Python及PyCharm安装教程【图文教程】
211 0
|
3月前
|
Python
Pycharm 如何更改成中文版| Python循环语句| for 和 else 的搭配使用
Pycharm 如何更改成中文版| Python循环语句| for 和 else 的搭配使用
22 0
|
3月前
|
机器学习/深度学习 测试技术 开发者
最新PyCharm下载安装以及Python环境搭建教程(含Python入门教程)
最新PyCharm下载安装以及Python环境搭建教程(含Python入门教程)
183 1