Django cursor()增删改查和shell环境执行脚本

        在Django中,cursor()方法是DatabaseWrapper对象(由django.db.connectio提供)的一个方法,用于创建一个游标对象。这个游标对象可以用来执行SQL命令,从而实现对数据库的增删改查操作。

查询(Select)

        使用cursor.execute()方法执行SQL查询语句,可以获取数据库中的数据。查询your_table表中的所有记录。执行查询后,你可以使用cursor.fetchall()或cursor.fetchone()等方法来获取查询结果。

cursor.execute("SELECT * FROM your_table")

插入(Insert)

        使用cursor.execute()方法执行SQL插入语句,可以向数据库中添加新的记录。插入一条新记录。这里%s是占位符,execute()方法的第二个参数是一个列表,包含了要插入的值。

cursor.execute("INSERT INTO your_table (column1, column2) VALUES (%s, %s)", [value1, value2])

更新(Update)

        使用cursor.execute()方法执行SQL更新语句,可以修改数据库中已存在的记录。例如,你可以使用来更新your_table表中id为某值的记录的column1字段。

cursor.execute("UPDATE your_table SET column1 = %s WHERE id = %s", [new_value, id])

删除(Delete)

使用cursor.execute()方法执行SQL删除语句,可以删除数据库中的记录。删除your_table表中id为某值的记录。

cursor.execute("DELETE FROM your_table WHERE id = %s", [id])

示例

1,添加模型

Test/app11/models.py

from django.db import modelsclass Post(models.Model):title = models.CharField(max_length=200)content = models.TextField()pub_date = models.DateTimeField('date published')class Book(models.Model):title = models.CharField(max_length=100)author = models.CharField(max_length=100)publication_date = models.DateField()price = models.DecimalField(max_digits=5, decimal_places=2)def __str__(self):return self.title

2,shell 环境执行脚本

python manage.py shell

2.1 查询数据

fetchone() 方法 查询单行数据

# fetchall() 方法 查询单行数据
from django.db import connection# 使用cursor执行SQL查询
with connection.cursor() as cursor:cursor.execute("SELECT * FROM app11_post WHERE id = (%s)",['2'])row = cursor.fetchone()if row:print(f"Post with id 2: {row}")
else:print("No post found with id 2")

 fetchall() 方法 查询所有数据

# fetchall() 方法 查询所有数据
from django.db import connection
from datetime import datetime# 使用cursor执行SQL查询获取所有Post
with connection.cursor() as cursor:cursor.execute("SELECT id, title, content, pub_date FROM app11_post")rows = cursor.fetchall()for row in rows:print(row)print('\n')
# 使用cursor执行SQL查询获取所有Book
with connection.cursor() as cursor:cursor.execute("SELECT id, title, author, publication_date, price FROM app11_book")rows = cursor.fetchall()for row in rows:print(row)

2.2 插入数据

from django.db import connection
from datetime import datetime
import pytz# 使用cursor执行SQL查询插入数据
with connection.cursor() as cursor:# 如果你的Django项目启用了时区支持,确保你的datetime对象是带有时区信息的pub_date = datetime(2023, 1, 1, 12, 0, 0, tzinfo=pytz.UTC)# 对于Post模型cursor.execute("INSERT INTO app11_post (title, content, pub_date) VALUES (%s, %s, %s)",['My First Post1321', 'This is the content of my first post.', pub_date])# 对于Book模型cursor.execute("INSERT INTO app11_book (title, author, publication_date, price) VALUES (%s, %s, %s, %s)",['My First Book1321', 'John Doe', '2023-01-01', 19.99])

也可以用save()方法

# 插入数据
from datetime import datetime
import pytz
from app11.models import Post# 创建一个Post对象
post = Post(title='My First Post123', content='This is the content of my first post.123', pub_date=datetime(2023, 1, 1, 12, 0, 0, tzinfo=pytz.UTC))
# 保存到数据库
post.save()# 插入数据
from datetime import datetime
import pytz
from app11.models import Book# 创建一个Book对象
book = Book(title='My First Book123', author='John Doe123', publication_date=datetime(2023, 1, 1, 12, 0, 0, tzinfo=pytz.UTC), price=19.99)# 保存到数据库
book.save()

2.3 更新数据

# 更新数据
from django.db import connection# 新的title和content值
new_title = 'Updated Title123'
new_content = 'Updated Content123'# 使用cursor执行SQL查询更新数据
with connection.cursor() as cursor:cursor.execute("UPDATE app11_post SET title=%s, content=%s WHERE id=5",[new_title, new_content])from django.db import connection# 新的title和price值
new_title = 'Updated Book Title123'
new_price = 29.99# 使用cursor执行SQL查询更新数据
with connection.cursor() as cursor:cursor.execute("UPDATE app11_book SET title=%s, price=%s WHERE id=5",[new_title, new_price])

2.4 删除数据

from django.db import connection# 要删除的记录的id
post_id = 5# 使用cursor执行SQL查询删除数据
with connection.cursor() as cursor:cursor.execute("DELETE FROM app11_post WHERE id = %s",[post_id])from django.db import connection# 要删除的记录的id
book_id = 5# 使用cursor执行SQL查询删除数据
with connection.cursor() as cursor:cursor.execute("DELETE FROM app11_book WHERE id = %s",[book_id])

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/380912.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

对象存储解决方案:高性能分布式对象存储系统MinIO

文章目录 引言I 自动化数据管理界面1.1 图形用户界面:GUI1.2 命令行界面:MinIO CLI1.3 应用程序编程接口:MinIO APIII 部署集成2.1 建议使用RPM或DEB安装方式2.2 创建环境变量文件2.3 启动MinIO服务2.4 将NGINX用作反向代理,配置负载。III 基础概念3.1 为什么是对象存储?3…

Python入门------pycharm加载虚拟环境

pycharm虚拟环境配置: 在按照前面的办法,配置好虚拟环境后,如果我们需要到虚拟环境开发,就需要给编译器配置虚拟环境 1.打开编译器,点击右下角的interpreter选项 2. 点击ADD Interpreter,添加虚拟环境 3. 因为我们使用的是原始…

CUDA编程00 - 配置CUDA开发环境

第一步: 在一台装有Nvidia显卡和驱动的机器上,用nvidia-smi命令查看显卡所支持cuda版本 第二步: 到Nvidia官网下载CUDA Toolkit并安装,CUDA Toolkit Archive | NVIDIA Developer 安装时按提示下一步即可,安装完成用 …

Linux源码安装的Redis如何配置systemd管理并设置开机启动

文章目录 实验前提实验 实验前提 已完成源码安装并能正常启动redis /usr/local/bin/redis-server能正常启动redis 实验 vim /etc/systemd/system/redis.service内容如下: [unit] Descriptionredis-server Afternetwork.target[Service] Typeforking ExecStart/…

JMeter介绍、安装配置以及快速入门

文章目录 1. JMeter简介2. JMeter安装配置3. JMeter快速入门 1. JMeter简介 Apache JMeter是一款开源的压力测试工具,主要用于测试静态和动态资源(如静态文件、服务器、数据库、FTP服务器等)的性能。它最初是为测试Web应用而设计的&#xff…

/秋招突击——7/21——复习{堆——数组中的第K大元素}——新作{回溯——全排列、子集、电话号码的字母组合、组合总和}

文章目录 引言复习数组中的第K大的最大元素复习实现参考实现 新作46 全排列个人实现参考实现 子集个人实现参考实现 电话号码的字母组合复习实现 组合总和个人实现参考实现 总结 引言 昨天的科大讯飞笔试做的稀烂,今天回来好好练习一下,主要是针对下述两…

GIS技能大赛解题过程(1)

试题要求:制作一幅广西区域发展布局示意图,最终成图参考如下。 做题步骤 一、创建数据库,整合数据入库 要求: 【解题步骤】 1、新建数据库命名为中间数据库.gdb,右键点击【export】导入数据,可以将数据拖…

单链表算法 - 链表分割

链表分割_牛客题霸_牛客网现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的。题目来自【牛客题霸】https://www.nowcoder.com/practice/0e27e0b064de4eacac178676ef9c9d70思路: 代码: /* struct ListNode {int val;struct List…

防火墙--内容安全

目录 概述 IAE引擎流程 DPI深度包检测 基于特征字的检测技术 基于应用网关的检测技术 基于行为模式的检测技术 DFI深度流检测 基于数据流进行识别检测的技术 DPI和DFI对比 IDS(入侵检测) IPS(入侵防御) 优势 入侵检测…

JVM之经典垃圾回收器

1.垃圾回收器的分类 处理范围划分: 新生代垃圾回收器:serial、parNew、parallel scavenge; 老年代垃圾回收器:serial Old、parallel Old、CMS; 整堆收集器:G1、ZGC; 2.Serial GC Serial是单…

数据结构——线性表(循环链表)

一、循环链表定义 将单链表中终端结点的指针端由空指针改为指向头结点,就使整个单链表形成一 个环,这种头尾相接的单链表称为单循环链表,简称循环链表(circular linked list)。 循环链表解决了一个很麻烦的问题。如何从当中一 个结点出发&am…

STM32测测速---编码电机读取速度的计算

1、首先先了解一下计算的公式 速度计算: 轮胎每转一圈的脉冲数取决于编码器的分辨率,可由下面公式进行计算: PPR是电机的线数 以GA25-370电机为例。 图片来源:第四节:STM32定时器(4.JGA25-370霍尔编码器…

【23】Android高级知识之Window(四) - ThreadedRenderer

一、概述 在上一篇文章中已经讲了setView整个流程中,最开始的addToDisplay和WMS跨进程通信的整个过程做了什么。继文章Android基础知识之Window(二),这算是另外一个分支了,接着讲分析在performTraversals的三个操作中,最后触发pe…

昇思25天学习打卡营第11天|基于 MindSpore 实现 BERT 对话情绪识别

BERT是一种先进的语言模型,由Google在2018年推出。它通过双向编码器Transformer的Encoder部分,捕捉词语和句子的深层含义。BERT的创新之处在于其预训练方法,特别是Masked Language Model和Next Sentence Prediction,这使得它在问答…

【python 已解决】ImportError: No module named ‘example‘ 详解与解决方案

【python 已解决】ImportError: No module named example 详解与解决方案 在Python编程中,ImportError是一个常见的异常类型,它表明Python解释器无法导入指定的模块。当你看到错误提示“ImportError: No module named ‘example’”时,这意味…

基于Llama Index构建RAG应用(Datawhale AI 夏令营)

前言 Hello,大家好,我是GISer Liu😁,一名热爱AI技术的GIS开发者,本文参与活动是2024 DataWhale AI夏令营;😲 在本文中作者将通过: Gradio、Streamlit和LlamaIndex介绍 LlamaIndex 构…

jenkins 使用教程

1. 安装最新长期稳定版 2.426.1 Redhat Jenkins Packages sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo --no-check-certificate sudo rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io-2023.key yum insta…

Linux云计算 |【第一阶段】ENGINEER-DAY2

主要内容: 磁盘空间管理fdisk、parted工具、开机自动挂载、文件系统、交换空间 KVM虚拟化 实操前骤: 1)添加一块硬盘(磁盘),需要关机才能进行操作,点击左下角【添加硬件】 2)选择2…

如何成为学习高手

文章收录在网站:http://hardyfish.top/ 文章收录在网站:http://hardyfish.top/ 文章收录在网站:http://hardyfish.top/ 文章收录在网站:http://hardyfish.top/ 所有的学习方式,核心都是动脑加动手。 区别在于如何让…

配置RIPv2的认证

目录 一、配置IP地址、默认网关、启用端口 1. 路由器R1 2. 路由器R2 3. 路由器R3 4. Server1 5. Server2 二、搭建RIPv2网络 1. R1配置RIPv2 2. R2配置RIPv2 3. Server1 ping Server2 4. Server2 ping Server1 三、模拟网络攻击,为R3配置RIPv2 四、在R…