连接数据库

配置文件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. 构建工具 Ant、Maven和Gradle

    构建工具的作用 依赖管理 测试,打包,发布 主流的构建工具 Ant:提供编译,测试,打包 Maven:在Ant的基础上提供了依赖管理和发布的功能 Gradle:在Maven的基础上使用Groovy管理 ...

  2. Jbuilder(3300✨)

    https://github.com/rails/jbuilder Jbuilder(3300✨) Jbuilder gives you a simple DSL for declaring JSON ...

  3. const关键字对C++成员函数的修饰

    const对C++成员函数的修饰分为三种:1. 修饰参数:2. 修饰返回值:3. 修饰this指针.简述一下知识点如下,以后找功夫再完善. 1. 对函数参数的修饰. 1)const只能用来修饰输入参数 ...

  4. 将C语言的CRC32 代码转成JAVA的CRC32 代码

    public class CustomerCRC32 { private static long[] crc32Table = new long[256]; static { long crcValu ...

  5. springboot模糊查询

    在学习MyBatis过程中想实现模糊查询,可惜失败了.后来上百度上查了一下,算是解决了.记录一下MyBatis实现模糊查询的几种方式. 数据库表名为test_student,初始化了几条记录,如图: ...

  6. Eclipse CDT 配置C /C ++ 标准库 (UBUNTU 12 )

    http://blog.csdn.net/wudiwo/article/details/7682320

  7. JAVA实现Excel导入/导出【转】

    JAVA实现Excel导入/导出[转] POI的下载与安装 请到网站http://www.apache.org/dyn/closer.cgi/poi/右击超链接2.5.1.zip下载压缩包poi-bi ...

  8. 高级浏览器-SRWare Iron 29.0.1600.0 版本发布

    SRWare Iron是德国一安全公司srware改造的Chrome(铬)命名为铁(iron)的浏览器.于2008年9月18日首次发布. 据官方介绍,Iron浏览器砍掉了Chromium原程序中的很多 ...

  9. protel 99se 加载库文件 files not recognised 解决办法-转

    WIN7操作系统下,protel99se添加元件库的操作方法(非修改ADVSch99SE方法) 最近更换了新电脑,操作系统是正版的WIN7,在用protel时发现元件库无法加载,很是郁闷,上网查找解决 ...

  10. 如何在CentOS7上安装MySQL并实现远程访问

    传送门 本人乃学生小白一枚,近期在学习Linux,所以就简单记录一下~ 安装MySQL 首先,需要检查一下是否已经安装了MySQL : # rpm -qa | grep mysql 这时候没有任何输出 ...