Django——ORM基础操作

本文介绍了ORM的概念及其在Python中的应用,特别是通过Django框架实现数据库操作的过程。包括ORM的优缺点、与SQL语句的关系,以及如何利用Django进行数据库的创建、配置和表的操作等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一,为什么使用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 =“张三”)

八、删除表:

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

### 使用 Django、MySQL 和 Vue 构建有声图书网站的最佳实践 #### 项目初始化与环境配置 为了启动一个基于Django和Vue的有声图书网站,需先设置好开发环境。这包括但不限于安装Python解释器以及确保所有必要的Django依赖库已就绪[^3]。 对于数据库的选择,在此案例中选用了MySQL作为后端存储解决方案,并通过Navicat这类工具来进行管理和维护工作。此外,还需注意版本兼容性问题;例如,文中提到使用了特定版本组合——Python 3.7.7搭配MySQL 5.7。 #### 后端开发 (Django) ##### 创建并配置Django应用 一旦环境准备完毕,则可着手建立新的Django工程及其内部的应用程序组件。考虑到项目的特殊需求(即提供在线听书服务),应当定义相应的数据模型来表示书籍信息、章节详情等内容实体。这些都将被保存至预先设定好的MySQL实例之中。 ```python from django.db import models class Book(models.Model): title = models.CharField(max_length=200) author = models.CharField(max_length=100) class Chapter(models.Model): book = models.ForeignKey(Book, on_delete=models.CASCADE) content_url = models.URLField() # 假设音频文件托管于外部CDN或云盘 ``` 上述代码片段展示了两个简单的ORM类映射关系,用于描述一本书籍与其所属各章节之间的关联形式。 ##### API接口设计 为了让前端能够顺利获取到所需的数据资源,必须精心规划RESTful风格的服务端点。借助`django-rest-framework`这样的第三方包可以帮助简化这一过程,从而使得开发者可以专注于业务逻辑本身而非底层通信细节。 #### 前端开发 (Vue.js) ##### 用户界面构建 在完成了基础架构之后,接下来就是打造直观易用的操作面板供访客浏览及收听电子读物之用了。这里推荐运用现代JavaScript框架之一—Vue.js 来完成这项任务。其声明式的语法糖特性极大地提高了编码效率的同时也降低了学习曲线[^4]。 利用HTML/CSS/JS编写静态页面元素,再配合Vue指令实现动态效果,比如加载进度条显示或是播放控制按钮等功能部件。与此同时,还可以考虑引入Element UI等UI库进一步美化整体外观样式。 ##### 客户端请求处理 最后一步便是让前后两端之间建立起有效的联系渠道。通常来说会采用AJAX异步调用来发起HTTP GET/POST 请求并与远端API进行交互。当然也可以探索WebSocket长连接机制以支持更加复杂的场景需求,不过对于本项目而言前者已经足够胜任了。 ```javascript axios.get('/api/books/') .then(response => { this.books = response.data; }) .catch(error => console.log(error)); ``` 这段脚本示范了怎样从服务器拉取最新发布的书籍列表并将结果显示给当前用户查看。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值