django ORM 数据库连接配置

前言

django 中连接数据,可以使用pymysql 也可以使用django 自带的框架ORM

pymysql 操作数据库

用pymysql连接MySQL数据库查询数据
1. import pymysql
2. 建立连接
3. 获取光标
4. 执行SQL语句
5. 获取数据
6. 关闭光标
7. 关闭连接

ORM是个啥

对象关系映射

类       数据表
属性      字段
对象        数据行

两者的比较

使用pymysql连接数据库缺点:
1. 麻烦
2. 自己写SQL语句!!!
使用ORM工具连接数据库
- 优点:
1. 不用自己写SQL语句!!!
- 缺点:
1. 执行效率不高(需要翻译成语句再去执行)

Django中如何使用ORM

1. 告诉Django连接哪个MySQL数据库(settings.py)

settings.py  中数据库连接配置
#默认的配置,默认使用的是django 自带的数据库sqlite3
# DATABASES = {
#     ‘default‘: {
#         ‘ENGINE‘: ‘django.db.backends.sqlite3‘,
#         ‘NAME‘: os.path.join(BASE_DIR, ‘db.sqlite3‘),
#     }
# }

DATABASES = {
    ‘default‘: {
        ‘ENGINE‘: ‘django.db.backends.mysql‘,         #引擎
        ‘NAME‘: ‘cmdb‘,                               #数据库名称
        ‘HOST‘:‘127.0.0.1‘,                           #主机地址
        ‘PORT‘:3306,                                  #端口
        ‘USER‘:‘root‘,                                #用户名
        ‘PASSWORD‘:‘111111‘,                          #密码
    }
}

2. 告诉Django用pymysql连接MySQL数据库 (默认用的是MySQLDB)

在项目的__init__.py 中加入如下配置

import pymysql
pymysql.install_as_MySQLdb()

3. 去app/models.py里面创建类

from django.db import models
class IDC(models.Model):
    """
    机房信息
    """
    name = models.CharField(‘机房‘, max_length=32)
    floor = models.IntegerField(‘楼层‘, default=1)

    class Meta:
        verbose_name_plural = "机房表"

    def __str__(self):
        return self.name

4. 让Django去数据库帮我创建类对应的数据表
  1. python manage.py makemigrations           --> 将models.py的改动记录在小本本上
  2. python manage.py migrate              --> 将变更记录翻译成SQL语句,去数据库执行

5、在django 中查看数据库表数据

  添加数据源(mysql 作为数据源)

  

配置数据库连接信息

  

  注意:第一次配置需要下载驱动,在此页面的下面有提示,下载可以。

  添加sqlite3 作为数据源

  

  注意:sqlite3 为文件数据库,数据库实体本身就在django项目目录内,直接右键作为数据源打开即可。

原文地址:https://www.cnblogs.com/fanggege/p/10327920.html

时间: 2024-10-02 07:01:56

django ORM 数据库连接配置的相关文章

Web框架之Django_02基本操作(Django项目启动配置、数据库连接、orm、增删改查)

摘要: Django项目简单现实过程 pycharm连接数据库 Django之orm简单操作增删改查 一.新建Django项目.配置.设置: 新建Django项目:(为了熟悉Django操作,暂时全部用cmd形式来实现,很多地方需要手动添加)项目目录D:\Django: >>管理员权限打开cmd,通过cmd命令进入项目目录 >>django-admin startproject my_Dproject (创建项目) >>cd my_Dproject (进入项目文件夹)

Django静态文件配置、request方法、ORM简介、字段的增删改查

app的创建注意事项: 在Django新创建的app要在seetings.py中添加注册,才会生效 创建app:django-adminapp an startapp app名称 或者 python3 mansge.py startpp名称 手动创建的app不会自带存放html的templates文件夹,需要手动创建 Django静态文件配置 对于前端已经写好了的文件,我们只是拿过来使用,那么这些文件都可以称之为"静态文件"; 静态文件可以是:boostrap一类的前端框架,已经写好了

Django orm使用教程

Django orm使用教程 标签(空格分隔): Django orm 前言 orm使用五步走: 在settings文件中设置数据库连接配置 创建app 在models里面创建类 使用python make migrations命令将改变登记在小本本上面 使用python migrate命令将改动同步到数据库中 数值类型(常用) CharField varchar类型:name = models.CharField(max_length=32) IntegerField int类型:age =

Django - - 基础 - - Django ORM常用查询语法及进阶

目录 一般操作 必知必会13条 单表查询之神奇的双下划线 ForeignKey操作 正向查找 反向操作 ManyToManyField class RelatedManager 聚合查询和分组查询 聚合 分组 F查询和Q查询 F查询 Q查询 锁和事务 锁 事务 其他鲜为人知的操作(有个印象即可) Django ORM执行原生SQL QuerySet方法大全 Django终端打印SQL语句 在Python脚本中调用Django环境 1, 一般操作 官网文档:https://docs.djangop

django orm基础

Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将程序中的对象自动持久化到关系数据库中. ORM在业务逻辑层和数据库层之间充当了桥梁的作用. ORM由来 让我们从O/R开始.字母O起源于"对象"(Object),而R则来自于"关系&qu

Django ORM操作及进阶

Django ORM操作及进阶 一.常规操作 1.必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误. <4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 <5> values(*field):

python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "orm_demo.settings") import django django.setup() # 启动Django项目 from app01 import models #返回QuerySet对象的方法: r

数据库表反向生成(二)django ORM inspectdb

在前一篇我们说了,mybatis-generator反向生成代码. 这里我们开始说如何在django中反向生成mysql model代码. 我们在展示django ORM反向生成之前,我们先说一下怎么样正向生成代码. 正向生成,指的是先创建model.py文件,然后通过django内置的编译器,在数据库如mysql中创建出符合model.py的表. 反向生成,指的是先在数据库中create table,然后通过django内置的编译器,生成model代码. 1.准备工作 创建django工程以及

Django ORM那些相关操作

一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误. <4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 <5> values(*field): 返回