四 Django-模型和数据库基础

一、简介

Django 模型是与数据库相关的,与数据库相关的代码一般写在 models.py 中,Django 支持 sqlite3, MySQL, PostgreSQL,oracle等数据库,只需要在settings.py中配置即可,不用更改models.py中的代码,丰富的API极大的方便了使用。

二、模型

模型是你数据的唯一的、确定的信息源。 它包含你所储存数据的必要字段和行为。 通常,每个模型对应数据库中唯一的一张表

三、前期准备工作

1、django对支持MySQL有三个主要的驱动程序

  • MySQLdb是Andy Dustman十多年来开发和支持的本地驱动程序,Django需要MySQLdb 1.2.3或更高版本。MySQLdb(1.2.5)的最新版本不支持Python 3,为了在Python 3下使用MySQLdb,需要安装mysqlclient
  • mysqlclient是一个MySQLdb特别支持Python 3 的分支,可以用作MySQLdb的插入替代品
  • MySQLconnector/ Python这个是纯python实现的MySQL接口,由Oracle维护(官方驱动)
  • pymysql

所有这些驱动程序都是线程安全的,并提供连接池。MySQLdb是目前唯一不支持Python 3的。

除了DB API驱动程序之外,Django还需要一个适配器才能从ORM访问数据库驱动程序。Django为MySQLdb / mysqlclient提供了一个适配器,而MySQL Connector/Python包含它自己的。

2、下载驱动

sudo pip install pymysql

需要导入到django中,打开应用下/__init__.py文件

import pymysql

pymysql.install_as_MySQLdb() # 与mysql交互的函数

3、创建数据库

指定编码和排序规则

CREATE DATABASE IF NOT EXISTS **yourdbname **DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

4、连接数据库

在settings.py中配置mysql连接参数(没有mysql的先装mysql),连接方式有三种

  1. NAME,USER,PASSWORD, HOST`,PORT
  2. MySQL配置文件。
  3. OPTIONS
  1. 在settings.py中通用配置
    DATABASES = {
      'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '数据库名',
        'USER':'mysql用户名(如root)',
        'PASSWORD':'密码(root)',
        'HOST':'域名(127.0.0.1或localhost)',
        'PORT':'端口号(3306)',
      }
    }
    
  2. MySQL配置文件
    # settings.py
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            #django.db.backends.postgresql  # PostgreSQL  
            #django.db.backends.sqlite3     # sqlite  
            #django.db.backends.oracle      # oracle 
            'OPTIONS': {
                'read_default_file': '配置文件路径/xxx.cnf',
            },
        }
    }
    #xxx.cnf
    [client]
    database = django
    user = root
    password = root
    host = 127.0.0.1
    port = 3306
    default-character-set = utf8
    
    #config.ini
    [global]
    ip = xxx
    port = xxx
    table = xxx
    uname = xxx
    passwd = xxx
    #读取本地配置文件用了个django自带的模块:configparser
    #在settings.py 中设置如下,按照相对路径取本地配置文件:
    import configparser
    import os
    dir_now = os.path.dirname(os.path.dirname(os.path.abspath("settings.py")))  # 路径自己指定,我这里是以settings.py为参考,abspath是取它的上级目录,也可以直接指定绝对路径来读取
    conf = configparser.ConfigParser()
    conf.read(dir_now+'/config.ini')  # 读config.ini文件
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',  # 使用mysql这样写就行了,是指明引擎的
            'NAME': conf.get('global', 'table'),  # 库名
            'USER': conf.get('global', 'uname'),  # 用户名
            'PASSWORD': conf.get('global', 'passwd'),  # 密码
            'HOST': conf.get('global', 'ip'),  # 数据库主机ip
            'PORT': conf.get('global', 'port'),  # 数据库端口号
        }
    }
    
  3. 其它
    # MySQL数据库配置项
    MYSQL_OPTIONS = {
        # 使用严格模式TRADITIONAL插入数据
        'sql_mode': 'TRADITIONAL',
        'charset': 'utf8',
        'init_command': """
       # 设置默认的数据库引擎   
        SET default_storage_engine=INNODB;
        # 设置连接的编码集 默认的排序方式
        SET character_set_connection=utf8,collation_connection=utf8_unicode_ci;
        # 设置数据库的事务级别
        SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
        """
    }
    DATABASES = {
        'default': {
         ...
       'OPTIONS': MYSQL_OPTIONS,
            # 设置数据库交互方式为事务
            'ATOMIC_REQUESTS': True,
           }
    ANSI模式:宽松模式,对插入数据进行校验,如果不符合定义类型或长度,对数据类型调整或截断保存,报warning警告。
    TRADITIONAL模式:严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不能插入,报error错误。用于事物时,会进行事物的回滚。
    STRICT_TRANS_TABLES模式:严格模式,进行数据的严格校验,错误数据不能插入,报error错误      
    

四、数据迁移

1、编写models.py

  1. 核心代码
    from django.db import models
    class Person(models.Model):
        SEX_CHOICES = (
            ('1', '男'),
            ('2', '女'),
        )
        pid = models.AutoField(primary_key=True)
        name = models.CharField(max_length=32)
        age = models.IntegerField()
        sex = models.CharField(max_length=2, choices=SEX_CHOICES)
        register_date = models.DateField(auto_now_add=True)
        class Mate:
            verbose_name = '人员信息'
            verbose_name_plural = verbose_name
        def __str__(self):
            return self.name
    
  2. 注意事项
    models.py必须命名成models否则数据迁移时检测不到

2、数据库迁移

  1. 说明
    这种方法可以在SQL等数据库中创建与models.py代码对应的表,不需要自己手动执行SQL。
    先 cd 进入 manage.py 所在的那个文件夹下,输入下面的命令
  2. Django 1.6.x 及以下
    #1.7版本之前,Django只支持新增模型到数据库中;通过syncdb(migrate的前身)命令变更或者删除现存的模型市不可能的。 
    #第三方工具,尤其是South,支持这些增加的变更类型,但是现在被认为已经足够重要到需要引入到django的core中去
    python manage.py syncdb
    
  3. Django 1.7 及以上的版本需要用以下命令
    #用来根据你对模型做的变更创建新的迁移脚本 
    python manage.py makemigrations  <app_name>(可选,指定模块,默认整个项目下的app)
    #用来使迁移生效,以及未生效时报告它们的状态。
    python manage.py migrate  <app_name>(可选,指定模块,默认整个项目下的app)
    
  4. 执行migrate命令后相当于如下sql语句
    #默认表名(包名+类名)
    CREATE TABLE `test_person` (
      `pid` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(32) NOT NULL,
      `age` int(11) NOT NULL,
      `sex` varchar(2) NOT NULL,
      `register_date` date NOT NULL,
       PRIMARY KEY (`pid`)
    )
    

3、通过表生成model

python manage.py inspectdb > app/models.py

五、其它数据库连接

1、oracle

  1. Oracle数据库的服务名称进行连接,在setting文件中进行如下配置
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.oracle',
            'NAME': '数据名',
            'USER': '用户名',
            'PASSWORD': '密码',
            'HOST': 'IP地址',
            'PORT': '端口',
        }
    }
    
  2. Threaded选项
    如果您打算在多线程环境中运行Django(例如,在任何现代操作系统上使用默认MPM模块的Apache),则必须threadedOracle数据库配置的选项设置为True:
    'OPTIONS': {
        'threaded': True,
    },
    
    但有可能导致一些意想不到的错误

2、配置控制台输出sql

  1. 在settings.py文件中
    LOGGING = {
     'version': 1,
     'disable_existing_loggers': False,
     'handlers': {
     'console':{
      'level':'DEBUG',
      'class':'logging.StreamHandler',
     },
     },
     'loggers': {
     'django.db.backends': {
      'handlers': ['console'],
      'propagate': True,
      'level':'DEBUG',
     },
     }
    }
    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,425评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,058评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,186评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,848评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,249评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,554评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,830评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,536评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,239评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,505评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,004评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,346评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,999评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,060评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,821评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,574评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,480评论 2 267

推荐阅读更多精彩内容