博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django之ORM操作
阅读量:6670 次
发布时间:2019-06-25

本文共 1593 字,大约阅读时间需要 5 分钟。

ORM介绍

对象关系映射(Object Relational Mapping,简称ORM)

ORM提供了对数据库的映射,不用直接编写SQL代码,只需操作对象就能对数据库操作数据。

类名对应       -->   数据库中的表名类属性对应     -->   数据库里的字段类实例对象对应  -->   数据库表里的一行数据

 

 

 

Django中的ORM

Django项目使用MySQL数据库

1. 在Django项目的settings.py文件中,配置数据库连接信息:

DATABASES = {    "default": {        "ENGINE": "django.db.backends.mysql",        "NAME": "你的数据库名称",  # 需要自己手动创建数据库        "USER": "数据库用户名",        "PASSWORD": "数据库密码",        "HOST": "数据库IP",        "PORT": 3306    }}

 

2. 在与Django项目同名的目录下的__init__.py文件中写如下代码,告诉Django使用pymysql模块连接MySQL数据库:

import pymysqlpymysql.install_as_MySQLdb()

 

3. 在app下的models.py中写类(models.Model):

class User(models.Model):    name = models.CharField(max_length=32)  # varchar(32)    pwd = models.CharField(max_length=32)  # varchar(32)

 

4. 执行数据库迁移的命令(app一定要在注册列表中,否则提示:No changes detected)

python manage.py makemigrations  # 保存每个APP下models的变更记录python manage.py migrate         #  将models的变更记录同步到数据库中

 

ORM单表操作

简单的增删改查

from app01 import models固定写法:models.User.objects     #User是类名,必须通过类名去操作表 # 插入数据 models.User.objects.create(name='lishichao')    #name 是字段名  'lishichao' 是要插入的数据 # 删除数据 modele.User.objects.filter(name='lishichao').delete()    # 先查询,再删除 # 修改数据 obj = models.User.objects.filter(name='lishichao')[0]  # 取第一个元素    先查询,再修改 obj.age = 18   # 在内存中修改  对象.属性,修改字段对应的数据 obj.save()     # 提交到数据库 # 查询所有结果ret = models.User.objects.all() print(ret)  # 对象列表 
]>for i in ret: print(i.name,i.pwd) # 对象的属性是一个字段 # 按条件查询 obj = models.User.objects.filter(name = 'lishichao@163.com',pwd = '123456') # 条件:字段名和要查询的数据 print(obj)

 

转载于:https://www.cnblogs.com/root0/p/10758002.html

你可能感兴趣的文章
ActiveMQ - JMS,Transport,Persistence
查看>>
互联网大数据支撑生态银行建设
查看>>
视频会议系统迎来第四次浪潮
查看>>
报告显示:被调研中国企业超85%已从数字转型中获得回报
查看>>
东方日升拉美光伏电站项目 将进入首期施工
查看>>
软件探索性测试 笔记二
查看>>
将来也不会被破译的分布式存储系统
查看>>
光伏电站或成辅助服务市场“输家”
查看>>
今年光伏“领跑者”计划将升级扩围
查看>>
Java程序运行超时后退出或进行其他操作的实现
查看>>
手把手教你启用RemoteFX以及Hyper-V GPU卸载
查看>>
《交互式程序设计 第2版》一3.10 更进一步
查看>>
英伟达发布Tesla P4&P40两款基于Pascal架构的深度学习芯片
查看>>
《ANSYS Workbench有限元分析实例详解(静力学)》——2.5 Windows界面相应操作
查看>>
《代码整洁之道:程序员的职业素养》一一1.3 首先,不行损害之事
查看>>
intellij 创建java web项目(maven管理的SSH)
查看>>
spring-java项目中连接redis数据库
查看>>
UML介绍--用例图
查看>>
阿里云DTS VS MySQLdump
查看>>
为android封装的百度定位组件
查看>>