连接数据库

配置文件settings

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 你的数据库引擎
'HOST': "localhost", # 你的数据地址,localhost代表本地
"PORT": 3306, # 端口, 数据库的默认端口一般是3306
"USER": "admin", # 用户名
"PASSWORD": "xxxx", # 密码
"NAME": "study" # 库名
}
}
如果你的数据库连接报错,
  1.缺少组件,可以安装以下的包
  • 安装依赖(如果使用虚拟环境,需要在虚拟环境下安装)
    • 安装mysql开发依赖包
  sudo apt-get install libmysqlclient-dev gcc
  2.ps: 如果出现连接被拒绝的错误:

    查看你的配置是否填写错误
    检查你的用户是否有远程权限
运行不报错则连接成功---------------------------------
创建表
  命令的执行过程:makemigrations(生成migrations文件,django通过这些文件创建表)
          migrate(迁移同步,通过生成的migartions文件创建表)  前提写好下面第一步
1.django创建表的类
# -*- coding: utf-8 -*-
from __future__ import unicode_literals from django.db import models # Create your models here. class Article(models.Model): # app名字+类名 生成表明 ps:app名字是hello,对应表名为 hello_article
title = models.CharField(max_length=50)
content = models.CharField(max_length=50) class Replay(models.Model):
content = models.CharField(max_length=50)

2.生成对应app的migrations文件  会自动生成id字段

  对已经存在的表进行修改,每执行一次makemigrations,会在该app的migrations文件下生成一个记录的py文件

  linux: python manage.py makemigrations  [appname]              可以不加appname,表示settings中的所有app,包括自带的app

  pycharm(选中项目名称)>tools>run manage.py Task...  进入命令行         输入命令 makemigrations  appname也可

3.迁移同步    同步数据库到mysql

同步之后:不能修改migrations文件  ps: 一套对应生成的migrations文件与数据库需保存一致,否则系统会报错!!!

linux:  python manage.py migrate  appname
pycharm  : migrate appname
 
************一套对应生成的migrations文件与数据库需保存一致,否则系统会报错!!!
   (1)不要对已经生成好的migrations文件做任何操作
   (2)所有对数据库的操作由同一个人做,并保留好一套migrations文件
   (3)不要直接在数据库中修改任何操作,比如修改字段,添加字段,删除字段等等;
 
当migrate迁移同步后:也就是创建好表后(migrations文件已经存在),如果新增字段,需要对新增字段进行设置 null=True 或者 default='xx' 
原因是 :django迁移同步后,生成的 migrations会记录表数据,而新增字段(没有数据)如果不指定字段可以为空或者设置默认值,它将不知道怎么展示数据      (已经存在的数据开始没这个字段,现在新增加字段时,你得给其它存在的数据添加新字段默认值或者null=True)
 
对已存在的表的字段进行增删
  在models里进行操作,新增字段则对新增字段进行设置 null=True 或者 default='xx' 
             删除字段则直接删除该字段代码
  最后都需要:makemigrations   +   migrate
 
当null=False, (不为空)如果不设置默认值 , 它默认为 空字符串 ' ',不符合django的上述限制条件
当null=False,default=None, 两者联合使用,才符合限制条件
 
 
 

django-连接数据库及创建表,已存字段的增删的更多相关文章

  1. django 做 migrate 时 表已存在的处理方法

    django 做 migrate 时 表已存在的处理方法 文章来源:嗨学网 http://www.piaodoo.com 在开发web的时候,如果是以前已存在的项目,项目下载下来后,为了使用测试库的数 ...

  2. Django中ORM创建表关系

    一:django中ORM创建表关系 ORM创建外键关系 1.表与表之间的关系 1.表与表之间的关系 一对多 一对一 多对多 2.操作目标条件: 图书表 出版社表 作者表 作者详情表 3.外键关联 一对 ...

  3. Django 之 文件配置、pycharm及django连接数据库、创表及表的增删改查02

    目录 创建项目后的文件夹配置 静态文件配置 接口前缀动态绑定 form表单回顾 根据请求方式的不同,返回前端不同的信息 pycharm 连接MYSQL数据库 Django 连接MYSQL数据库的配置 ...

  4. ORM以及Django使用ORM创建表

    day61 2018-04-28 1. 内容回顾 1. HTTP协议消息的格式: 1. 请求(request) 请求方法 路径 HTTP/1.1\r\n k1:v1\r\n ...\r\n \r\n ...

  5. django 做 migrate 时 表已存在的处理

    在开发web的时候,如果是以前已存在的项目,项目下载下来后,为了使用测试库的数据,会直接将整个测试库(如sqlite3)拿到本机来.这种情况下,如果执行的顺序不对,很容易在执行migrate的时候出现 ...

  6. mysql 重复执行创建表、新增字段脚本

    #bigint 可重复执行创建表脚本 1 Create Table If Not Exists `库名`.`表名`( 2 字段列表 3 ) ENGINE=InnoDB DEFAULT CHARSET= ...

  7. Oracle创建表、修改字段类型

    1.创建表 1.创建表 create table SCM_PER( --SCM_PER表名 ID ) primary key,--主键ID USERID ),--用户ID --Permission v ...

  8. Hibrenate实现根据实体类自动创建表或添加字段

    Hibernate支持自动建表,在开发阶段很方便,可以保证hbm与数据库表结构的自动同步. 实现: 在配置hibernate的配置文件中将hbm2ddl.auto设置为update,如:Xml代码&l ...

  9. python pymysql连接数据库并创建表

    之前看菜鸟教程 #!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost"," ...

随机推荐

  1. php--------网页开发实现微信JS的(定位,地图显示,照片选择功能)

    今天说说微信网页开发中一下JS的功能,分享一下,希望对各位有所帮助. 前提:要有公众号,和通过微信认证,绑定域名,得到相应信息,appid,appsecret等. 微信开发文档:https://mp. ...

  2. UVA-810 A Dicey Problem (BFS)

    题目大意:滚骰子游戏,骰子的上面的点数跟方格中的数相同时或格子中的数是-1时能把格子滚过去,找一条从起点滚到起点的路径. 题目大意:简单BFS,状态转移时细心一些即可. 代码如下; # include ...

  3. gradle ssh 插件

    org.hidetake.ssh Gradle SSH Plugin is a Gradle plugin which provides remote command execution and fi ...

  4. laravel框架中使用Validator::make()方法报错

    在控制器中用到了Validator::make(),它默认是use Dotenv\Validator; 但这样会出现 FatalErrorException错误 call to undefined m ...

  5. mysql中limit的用法详解[数据分页常用]

    在我们使用查询语句的时候,经常要返回前几条或者中间某几行的数据,这个时候怎么办呢?不用担心,mysql已经为我们提供了这样一个功能. SELECT * FROM table LIMIT [offset ...

  6. bzoj1077

    题解 这道题n的范围很小,所以我们可以考虑枚举+判定 设放在天平右边的是C,D. 以A+B<C+D为例,因为差分约束必须是差的形式,所以我们将式子变形 B−C<D−A然后枚举D,A的取值, ...

  7. 作业要求20181023-4 Alpha阶段第2周/共2周 Scrum立会报告+燃尽图 03

    作业要求[https://edu.cnblogs.com/campus/nenu/2018fall/homework/2284] 版本控制:https://git.coding.net/liuyy08 ...

  8. springboot整合mybatis增删改查(二):springboot热部署

    SpringBoot整合热部署 传统情况下, 我们用idea运行springboot程序时, 如果我们需要修改类里的方法,或者其他信息 我们需要修改完保存,并且重启springboot,有时候会很浪费 ...

  9. .NET/C# 使用反射注册事件

    使用反射,我们可以很容易地在运行时调用一些编译时无法确定的属性.方法等.那么如何注册事件呢? 本文将介绍如何使用反射注册事件. 本文内容 不使用反射 使用反射 安全地使用反射 参考资料 不使用反射 例 ...

  10. Python Logger使用

    1. 单文件的logging配置 import logging logging.basicConfig(level=logging.DEBUG, format='%(asctime)s %(filen ...