Djang链接mysql

Django 链接mysql(settings.py)
 DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',                    # 你的数据库引擎
        'HOST': "localhost",                                                # 你的数据地址,localhost代表本地
        "PORT": 3306,                                                        # 端口, 数据库的默认端口一般是3306
        "USER": "root",                                                      # 用户名
        "PASSWORD": "mima",                                        # 密码
        "NAME": "study"                                                    # 库名
    }
}

添加APP(settings.py)

# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    #'hello.apps.HelloConfig',
    'my_tools',
    'hello',  #添加APP
]
在APP下的models.py添加
# -*- coding: utf-8 -*-
from __future__ import unicode_literals

from django.db import models

# Create your models here.
# class Article(models.Model):
#     title = models.CharField(u"标题", max_length=50, null=False)  # 定义一个标题
#     content = models.TextField(u"内容", null=False)  # 定义一个主题内容

#第一个TABLES
class Article(models.Model):
    title = models.CharField(u"标题", max_length=50, null=False)  #定义一个标题
    content = models.TextField(u"内容", null=False)  #定义一个主题
    auther = models.CharField(u"作者",max_length=50, default="")
    status = models.IntegerField(default=1)    # 定义一个字段


#第二个TABLES
class Project(models.Model):
    allnames = models.CharField(u"name", max_length=50, null=False)
# -*- coding: utf-8 -*-
from __future__ import unicode_literals

from django.db import models

# 使用makemigrations 命令需要事项
# 1、一但将生成的migrations文件通过migrate命令同步至数据库以后,被操作的migrations文件不能再操作
# 2、如何避免上面的情况:
#     (1)不要对已经生成好的migrations文件做任何操作
#     (2)所有对数据库的操作同一个人做,并保留好一套migrations文件
#     (3)不要直接在数据库中修改任何操作,比如修改字段,添加字段,删除字段等等;

class Article(models.Model):
    # 如果没有添加主键,django会默认添加一个ID的主键
    title = models.CharField(max_length=50)
    content = models.CharField(max_length=50)
    reply = models.CharField(max_length=50, null=False)
    # 如果是新增的字段
    # 要么设置它允许为空 例:null=True
    # 要么设置一个默认值,例:default=""
    # 这个是数据库的规则,因为如果是新增的字段,
    # 没有默认值或者不允许为空的话,数据库是不知道这个字段要怎么展示
    comment = models.CharField(max_length=50, null=True)
    status = models.IntegerField(default=1)


class Reply(models.Model):
    content = models.CharField(max_length=50)
执行迁移
 python manage.py makemigrations [APPnaem]
 python manage.py migrate [APP name]

django 对数据库的表的修改(如新建、新增、删除表的字段)(表结构)都是在models文件下操作

django 对数据库数据的增删改查
#引入models
from .models import Article,Project

#增加
class ModelTest(View):
    def get(self,request):
        #新增数据方式1
        # article = Article()
        # article.title = "名字11111111111111111"
        # article.content ="内容1111**"
        # article.auther ="作者1111111111"
        # article.save()

        #新增数据方式2
        # Article(title="第二条22222222",
        #         content="内容22222222",
        #         auther="作者22222222",).save()
        return HttpResponse("OK")

#查询
#查询数据库.查询所有的表数据 == select * from  hello_Article;
        arti = Article.objects.all()

#查询单个数据 == select * fron hello_Article id=1
        # pk 等同于ID,主键名
        find1 = Article.objects.get(pk=1)
        find2 = Article.objects.get(id=1)
class ModelClsect(View):
    #数据查询
    def get(self, request):
        arti = Article.objects.all()
        find1 = Article.objects.get(pk=1)
        find2 = Article.objects.get(id=1)
        return render(request,"modelsshow.html",locals())

#删除
        #批量删除:== DELETE FROM hello_Article WHERE id 2 >1
        #找不到数据,不会删除
        Article.objects.filter(status=1).delete()

        #删除单个 == delete from hello_Article where id=1
        #不存在,就报错
        Article.objects.get(id=1).delete()

#修改
        #批量修改数据 update hello_Article status=3 where status=2
        Article.objects.filter(status=2).update(status=3)

        #单个批量修改
        sss = Article.objects.get(status=3)
        sss.status =3
        sss.save()
        #or
        #Article.objects.get(pk=1).save(status=3)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • 切换到创建项目的目录 cd C:\Users\admin\Desktop\DjangoProject创建名为pr...
    在努力中阅读 3,267评论 2 3
  • 已经同步到gitbook,想阅读的请转到gitbook: Django 1.10 中文文档 This tutori...
    leyu阅读 2,682评论 3 13
  • 模块间联系越多,其耦合性越强,同时表明其独立性越差( 降低耦合性,可以提高其独立性)。软件设计中通常用耦合度和内聚...
    riverstation阅读 2,068评论 0 8
  • Web框架之Django: (1)简介: Django是一个由Python写成开源的重量级Web应用框架,采用MT...
    老肖阅读 3,048评论 0 18
  • 上面这两个图片是ORM对象关系映射的关系理解。 django框架 一、简介 web框架 具体介绍django之前,...
    AAA年华阅读 2,353评论 0 2