开发者社区> 技术小阿哥> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
pycharm professional远程编程配置
pycharm professional远程编程配置
20 0
Pycharm的安装并且连接已有的Python环境实现自由编译(附中文配置)|并通过Pycharm实现增加网站访问
Pycharm的安装并且连接已有的Python环境实现自由编译(附中文配置)|并通过Pycharm实现增加网站访问
23 0
配置Pycharm的Scrapy爬虫Spider子类通用模板
配置Pycharm的Scrapy爬虫Spider子类通用模板
16 0
Pycharm新建文件模板配置
Pycharm新建文件模板配置
11 0
Github Copilot的申请及在Pycharm的配置和使用
文章目录 目录 Github Copilot的申请及在Pycharm的配置和使用 2022/06/29更新 1.简介 2.copilot首页 3.copilot的申请 4.GitHub Copilot 官方使用文档 5.PyChram下载地址 6.Pychram下载 GitHub Copilot 7.jetbrains系列官方教程 8.申请通过之后的操作 9.使用过程 10.相关功能键: 11.退出Github Copilot
65 0
Sentry 开发者贡献指南 - 配置 PyCharm
Sentry 开发者贡献指南 - 配置 PyCharm
23 0
Pycharm详细安装教程+PyCharm中配置Anaconda
Pycharm详细安装教程+PyCharm中配置Anaconda
44 0
Python3+PyCharm环境的安装及配置
近期碰到有同学入门Python还不会安装并配置Python编程环境的,在这里做一期教程手把手教大家安装与配置使用(以 Python 3.9.9 以及 PyCharm 2021.3.1 为例)
114 0
13688
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载