IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> Django3.2的ORM增删改查 -> 正文阅读

[Python知识库]Django3.2的ORM增删改查

14.2ORM

ORM可以帮助我们做两件事

  • 创建,修改,删除数据库中的表(不用你写SQL语句)
  • 操作表中的数据(不用写SQL语句)

14.2.1创建数据库

create database gx_day15 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

14.2.2django连接数据库

settings.py文件中

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME':'gx_day15',
        'USER':'root',
        'PASSWORD':"123456",
        "HOST":"127.0.0.1",
        "PORT":"3306"
    }
}

14.2.3django操作表

  • 创建表
  • 删除表
  • 修改表

1.创建表:在app01/models.py文件中

from operator import mod
from django.db import models

# Create your models here.
class UserInfo(models.Model):
    name=models.CharField(max_length=32)
    password=models.CharField(max_length=64)
    age=models.IntegerField()

执行命令:

python manage.py makemigrations
python manage.py migrate
注意:app需要提前注册

2.添加表

class Department(models.Model):
    title=models.CharField(max_length=16)

class Role(models.Model):
    caption=models.CharField(max_length=16)

再次执行命令:

python manage.py makemigrations
python manage.py migrate

3.删除表

class Department(models.Model):
    title=models.CharField(max_length=16)

#class Role(models.Model):
#    caption=models.CharField(max_length=16)

再次执行命令:

python manage.py makemigrations
python manage.py migrate

4.删除表的字段

from operator import mod
from django.db import models

# Create your models here.
class UserInfo(models.Model):
    name=models.CharField(max_length=32)
    password=models.CharField(max_length=64)
    #age=models.IntegerField()

再次执行命令:

python manage.py makemigrations
python manage.py migrate

5.增加表的字段

from operator import mod
from django.db import models

# Create your models here.
class UserInfo(models.Model):
    name=models.CharField(max_length=32)
    password=models.CharField(max_length=64)
    #age=models.IntegerField()
    # 1.没有默认值增加字段
    # 执行命令会出现选项1和选项2,选择选项1,输入默认值
    size=models.IntegerField()
    # 2.有默认值增加字段
    age=models.IntegerField(default=2)
    # 3.增加字段允许内容为空
    data=models.IntegerField(null=True,blank=True)

再次执行命令:

python manage.py makemigrations
python manage.py migrate

15.orm增删改查

urls.py

from django.contrib import admin
from django.urls import path
from app01 import views

urlpatterns = [
    path('orm/', views.orm),
]

views.py

#第一种引入方式,指定引入
from app01.models import Department,UserInfo
#第二种引入方式,引入全部
#from app01 import models
from django.shortcuts import render,HttpResponse,redirect
def orm(request):
    # Department.objects.create(title="销售部")
    # Department.objects.create(title="IT部")
    # Department.objects.create(title="运营部")
    #1.新建
    UserInfo.objects.create(name="test",password="123456",age=20)
    
    #2.删除
    UserInfo.objects.filter(id=1).delete()
    UserInfo.objects.all().delete()

    #3.获取数据
    #data_list=[对象,行,行] QuerySet类型
    data_list=UserInfo.objects.all()
    for obj in data_list:
        print(obj.id,obj.name,obj.password,obj.age)
    
    # 4.更新数据
    UserInfo.objects.filter(id=1).update(age=999)
   
    return HttpResponse("成功")

models.py

from operator import mod
from django.db import models

class UserInfo(models.Model):
    name=models.CharField(max_length=32)
    password=models.CharField(max_length=64)
    age=models.IntegerField(default=2)
   
class Department(models.Model):
    title=models.CharField(max_length=16)

访问127.0.0.1:8000/orm,返回成功

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 11:14:27  更:2022-05-05 11:16:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 8:48:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计