Django——ORM基础操作

7 篇文章 0 订阅

一,为什么使用ORM:
       1。不同的程序员写的SQL水平参差不齐
       2。执行效率也参差不齐

二,python语法 - 自动翻译 - > SQL语句

jQuery                      DOM
$("#d1")        --自动翻译-->  document.getElementById("d1")

三,ORM优缺点
       优点:
              1。简单,不用自己写SQL语句
              2。开发效率高
       缺点:
              1。记忆你这个特殊的语法
              2。相对于更严格灵活的人工的SQL语句,肯定执行效率有差距        

四,ORM的对应关系:
        类--->数据表
        对象--->数据行
        属性--->字段

五,ORM能做的事儿:
        1.操作数据表 - >创建表/删除表/修改表
            操作models.py里面的类
        2。操作数据行 - >数据的增加改查
            
注意:ORM不能创建数据库,需要自己动手创建数据库!
        
六,使用Django的ORM详细步骤:
        1。自己动手创建数据库
            创建数据库数据库名;(终端或可视化工具里)
        2.在Django项目中设置连接数据库的相关配置(告诉Django连接哪一个数据库)
            #数据库相关的配置(setting.py(与项目同名文件夹内))

DATABASES = {
                'default': {
                    'ENGINE': 'django.db.backends.mysql',  # 连接的数据库类型
                    'HOST': '127.0.0.1',  # 连接数据库的地址
                    'PORT': 3306,  # 端口
                    'NAME': "day61",  # 数据库名称
                    'USER': 'root',  # 用户
                    'PASSWORD': '123456'  # 密码
                }
            }


        3.告诉Django用pymysql代替默认的MySQLDB连接MySQL数据库
            在项目下app目录的__init__.py文件中,写下面两句:

                import pymysql
                # 告诉Django用pymysql来代替默认的MySQLdb
                pymysql.install_as_MySQLdb()#(MySQLdb不支持中py3)

        4.在app下面的models.py文件中定义一个类,这个类必须继承models.Model

            class 类名(models.Model):
                ...

            示例:

from django.db import models

# Create your models here.
#ORM(数据库相关操作)相关的只能写在这个文件里,卸载文件里Django不识别
# OPM对应关系:类对应数据表,对象对应数据行,属性对应字段
class UserInfo(models.Model):
    id = models.AutoField(primary_key=True) # 创建自增的一个主键
    name = models.CharField(null=False, max_length=20) #varchar且不能为空的字段

         5.终端内(项目文件夹下)执行两个命令,ORM自动按照对应关系创建数据表
            

1. python3 manage.py makemigrations #记录models.py中改动内容
2. python3 manage.py migrate        #吧改动翻译成SQL语句


七,ORM单表的增加和查询:
        1.查询
            models.UserInfo.objects.all()
        2.增加
            models.UserInfo.objects.create(name =“张三”)

八、删除表:

         很简单,,,,把对应的类注释掉然后再执行那个命令就行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值