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