一,为什么使用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 =“张三”)
八、删除表:
很简单,,,,把对应的类注释掉然后再执行那个命令就行