「异步魔法:Python数据库交互的革命」(一)

news2024/11/15 18:28:54

Hi,我是阿佑,今天将和大家一块打开异步魔法的大门,进入Python异步编程的神秘领域,学习如何同时施展多个咒语而不需等待。了解asyncio的魔力,掌握Async SQLAlchemy和Tortoise-ORM的秘密,让你的数据库操作快如闪电!

文章目录

  • Python进阶之数据库交互详解
    • 1. 引言
      • 数据库在现代应用中的核心作用
      • Python进行数据库交互的重要性
    • 2. 背景介绍
      • 2.1 数据库基础概念
        • 关系型数据库与非关系型数据库概述
        • SQL语言基础
      • 2.2 Python数据库交互发展历程
        • 从DB-API到ORM的演变
    • 3. DB-API标准与使用
      • 3.1 DB-API介绍
        • 规范概览与兼容性说明
      • 3.2 实战示例:使用SQLite
        • 连接数据库
        • 执行SQL查询与事务处理
        • 参数化查询与错误处理
    • 4. SQLAlchemy:Python ORM详解
      • 4.1 SQLAlchemy核心组件
        • Engine与Session管理
        • ORM映射:`declarative_base`与`Table`对象
      • 4.2 CRUD操作实践
        • 创建(Create)
        • 查询(Read)
        • 更新(Update)
        • 删除(Delete)
      • 4.3 高级特性
        • 关系与关联表
        • 查询表达式与过滤条件
        • 事物与并发控制
    • 5. Django ORM与模型设计
      • 5.1 Django项目中的数据库配置
        • 设置数据库连接
        • 定义模型(Model)
      • 5.2 数据迁移与操作
        • 自动化的数据库迁移
        • 简洁的数据库操作API
      • 5.3 高级查询与聚合函数
        • QuerySet的高级用法
        • 聚合与分组功能
    • 6. 小结

Python进阶之数据库交互详解

1. 引言

今天,阿佑要带大家进入一个充满魔力的世界——Python数据库交互的世界。别担心,我保证这趟旅程既有趣又实用,就像在魔法学院学习如何使用魔杖一样。

数据库在现代应用中的核心作用

想象一下,如果你是一个魔法师,你的魔法书就是数据库。它记录着你所有的咒语和魔法,而且每次施法时,你都可以快速地查找和使用它们。在现代应用中,数据库扮演着类似的角色。无论是在线购物平台、社交媒体还是企业资源规划系统,数据库都是它们的核心,存储着海量的数据,让这些系统能够快速、准确地响应用户的需求。

Python进行数据库交互的重要性

现在,让我们来谈谈Python。Python是一种非常流行的编程语言,它简洁、易学且功能强大。当Python遇上数据库,就像是魔法师找到了他的魔杖——两者结合,可以创造出无限可能。Python进行数据库交互,可以让开发者轻松地与数据库进行沟通,执行各种数据操作,从而构建出功能强大的应用程序。

在这个引言部分,我们只是简单地介绍了数据库的重要性和Python在数据库交互中的作用。接下来,我们将深入探索Python与数据库交互的世界,学习如何使用Python来操作数据库,就像魔法师学习如何使用他的魔杖一样。准备好了吗?让我们开始这段神奇的旅程吧!

在这里插入图片描述

2. 背景介绍

2.1 数据库基础概念

让我们继续我们的魔法之旅。在开始施展魔法之前,我们需要了解一些基本概念。数据库,就像一个庞大的图书馆,里面藏有无数的书籍(数据)。这些书籍被分类存放,方便我们找到所需的知识。

关系型数据库与非关系型数据库概述

在魔法世界里,有两种主要的图书馆:一种是传统的图书馆,它们的书籍按照严格的分类系统排列,这就是关系型数据库。另一种是现代的图书馆,书籍的摆放更加自由,可以根据读者的兴趣和需求来组织,这就是非关系型数据库

关系型数据库使用表格来组织数据,表格之间通过关系(如外键)相互连接。它们非常适合处理结构化数据,就像魔法师按照元素、咒语和仪式来组织他们的魔法书。

非关系型数据库则更加灵活,它们可以存储各种格式的数据,如文档、图片、视频等。它们不需要固定的表格结构,就像一个充满创意和自由的图书馆,可以容纳任何形式的魔法书籍。

SQL语言基础

在魔法世界中,有一种语言可以让魔法师与他们的图书馆沟通,这就是SQL(结构化查询语言)。SQL是一种强大的语言,它允许魔法师查询、更新、插入和删除图书馆中的书籍(数据)。

2.2 Python数据库交互发展历程

从DB-API到ORM的演变

在Python的世界中,魔法师们(开发者)一直在寻找更高效的方式来与数据库图书馆沟通。最初,他们使用DB-API,这是一个简单的接口,允许Python与数据库进行基本的交互,就像使用简单的咒语与图书馆进行基本的沟通。

随着时间的推移,魔法师们发现他们需要更强大的工具来处理更复杂的任务。于是,ORM(对象关系映射)出现了。ORM就像一个高级的魔法,它允许魔法师用Python代码来操作数据库,而不需要编写复杂的SQL语句。这使得数据库操作变得更加直观和易于管理。


在这一章节,我们介绍了数据库的基本概念,以及Python与数据库交互的发展历程。下一章,我们将深入探讨DB-API标准及其在Python中的使用,就像学习如何使用更高级的魔法咒语一样。准备好了吗?让我们继续前进!

3. DB-API标准与使用

3.1 DB-API介绍

欢迎回到我们的Python魔法课程。今天,我们要学习的是DB-API,这是Python世界中与数据库图书馆沟通的基础咒语集。想象一下,你手中有一本古老的魔法书,里面记载着如何与数据库进行交流的秘诀。

规范概览与兼容性说明

DB-API是Python数据库访问的一个标准接口,就像是所有魔法师都必须遵守的魔法规则。无论你使用的是哪种数据库,SQLite、MySQL还是PostgreSQL,DB-API都提供了一套统一的方式来执行基本的数据库操作。这就像是无论你在哪个魔法学院学习,基本的咒语和施法手势都是相同的。

3.2 实战示例:使用SQLite

现在,让我们通过一个实际的例子来展示DB-API的魔力。我们将使用SQLite,这是一个轻量级的数据库,非常适合初学者和小型项目。想象一下,SQLite就像是一个随身携带的小魔法书,随时可以拿出来使用。

连接数据库

首先,我们需要连接到我们的数据库。这就像是打开你的魔法书,准备开始施法。

import sqlite3

# 连接到SQLite数据库
# 如果文件不存在,会自动在当前目录创建一个数据库文件
conn = sqlite3.connect('my_magic_library.db')
print("已连接到魔法图书馆!")
执行SQL查询与事务处理

接下来,我们可以开始查询我们的魔法书了。在DB-API中,我们使用cursor对象来执行SQL命令。

# 创建一个cursor对象
cursor = conn.cursor()

# 执行一个查询
cursor.execute("SELECT * FROM spells")

# 获取查询结果
spells = cursor.fetchall()
for spell in spells:
    print(spell)

# 提交事务
conn.commit()
参数化查询与错误处理

在施法时,我们要小心,不要念错咒语。在DB-API中,我们使用参数化查询来避免错误和SQL注入攻击。

# 参数化查询
spell_name = "Levitation"
cursor.execute("SELECT * FROM spells WHERE name=?", (spell_name,))
levitation_spell = cursor.fetchone()
print(f"找到了咒语: {levitation_spell[1]}")

如果施法出错了怎么办?DB-API提供了错误处理机制,就像是一个魔法防护罩,保护我们免受错误的侵害。

try:
    # 尝试执行一个错误的SQL语句
    cursor.execute("SELEC * FROM spells")
except sqlite3.Error as error:
    print("哎呀,施法出错了:", error)
finally:
    # 不管成功还是失败,都要关闭防护罩
    conn.close()
    print("防护罩已关闭,魔法图书馆已安全关闭。")

通过这个章节,我们学习了DB-API的基本概念和如何使用SQLite进行数据库操作。就像学会了如何使用基础的魔法咒语,你现在可以开始探索更高级的魔法了。下一章,我们将深入了解SQLAlchemy,这是一个强大的ORM工具,可以让你的数据库操作更加强大和灵活。准备好了吗?让我们继续前进,探索更多的魔法吧!
在这里插入图片描述

4. SQLAlchemy:Python ORM详解

4.1 SQLAlchemy核心组件

欢迎来到Python数据库魔法的下一课!今天我们要探索的是SQLAlchemy,这是一个强大的ORM(对象关系映射)库,它可以让你像操作Python对象一样轻松地操作数据库。想象一下,你有一个魔法棒,只需要轻轻一挥,就可以在数据库中创建、查询、更新和删除数据。

Engine与Session管理

在SQLAlchemy的世界中,Engine是你的魔法棒,它负责与数据库建立连接。而Session则是你的魔法助手,帮助你管理数据库事务。

from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker

# 创建一个Engine,连接到数据库
engine = create_engine('sqlite:///my_magic_library.db')

# 创建Session类的实例
Session = sessionmaker(bind=engine)
session = Session()
ORM映射:declarative_baseTable对象

在ORM的世界里,你需要定义你的数据模型。declarative_base是你的魔法图纸,它允许你定义Python类来映射数据库表。

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String

Base = declarative_base()

class Spell(Base):
    __tablename__ = 'spells'

    id = Column(Integer, primary_key=True)
    name = Column(String)
    description = Column(String)

    def __repr__(self):
        return f"<Spell(name='{self.name}', description='{self.description}')>"

4.2 CRUD操作实践

CRUD代表创建(Create)、读取(Read)、更新(Update)和删除(Delete),这是数据库操作的基本四个动作。在SQLAlchemy中,这些操作变得非常简单。

创建(Create)
# 创建一个新的咒语
new_spell = Spell(name="Invisibility", description="Makes the caster invisible.")
session.add(new_spell)
session.commit()
print("咒语已添加到魔法图书馆!")
查询(Read)
# 查询所有的咒语
spells = session.query(Spell).all()
for spell in spells:
    print(spell)
更新(Update)
# 更新一个咒语的描述
spell_to_update = session.query(Spell).filter_by(name="Invisibility").first()
if spell_to_update:
    spell_to_update.description = "Makes the caster completely invisible."
    session.commit()
    print("咒语描述已更新!")
删除(Delete)
# 删除一个咒语
spell_to_delete = session.query(Spell).filter_by(name="Invisibility").first()
if spell_to_delete:
    session.delete(spell_to_delete)
    session.commit()
    print("咒语已从魔法图书馆中移除!")

4.3 高级特性

关系与关联表

在魔法世界中,咒语之间可能存在某种联系。SQLAlchemy允许你定义这些关系,就像连接不同的魔法书。

class Wizard(Base):
    __tablename__ = 'wizards'
    id = Column(Integer, primary_key=True)
    name = Column(String)
    spells = relationship("Spell", back_populates="wizard")

Spell.wizard = relationship("Wizard", back_populates="spells")
查询表达式与过滤条件

SQLAlchemy提供了强大的查询表达式,让你可以轻松地过滤和排序数据。

# 查询名字包含'Fire'的咒语
fire_spells = session.query(Spell).filter(Spell.name.like('%Fire%')).all()
事物与并发控制

事务是数据库操作中非常重要的概念,它确保了数据的一致性和完整性。

# 开启一个新的事务
with session.begin():
    # 在这里执行你的数据库操作
    pass

通过这一章节,我们学习了SQLAlchemy的核心组件和如何进行CRUD操作,还探索了一些高级特性。就像掌握了更高级的魔法,你现在可以更有效地与数据库进行交互了。下一章,我们将进入Django的世界,看看它是如何处理ORM和模型设计的。准备好了吗?让我们继续我们的魔法之旅!

5. Django ORM与模型设计

5.1 Django项目中的数据库配置

嘿,魔法师们!欢迎来到Django的奇妙世界,在这里,我们将学习如何用Django ORM来施展我们的数据库魔法。Django,这个强大的框架,就像一个全功能的魔法塔,让我们的数据库操作变得既简单又强大。

设置数据库连接

首先,我们需要告诉Django我们的数据库图书馆在哪里。这就像是在魔法塔的地图上标记出图书馆的位置。

settings.py文件中,我们可以这样设置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'my_magic_library.db',
    }
}

这段代码告诉Django,我们使用的是SQLite数据库,并且数据库文件叫做my_magic_library.db

定义模型(Model)

接下来,我们需要定义我们的魔法模型。在Django中,模型就像是数据库中的表格,它们定义了数据的结构。

from django.db import models

class Spell(models.Model):
    name = models.CharField(max_length=100)
    description = models.TextField()
    is_dark_arts = models.BooleanField(default=False)

    def __str__(self):
        return self.name

在这个例子中,我们定义了一个Spell模型,它有三个字段:name(咒语名称),description(咒语描述),以及is_dark_arts(是否属于黑魔法),最后一个字段默认为False

5.2 数据迁移与操作

自动化的数据库迁移

Django的迁移系统就像是魔法塔中的自动图书分类机,它可以帮助我们自动创建和更新数据库结构。

每当我们修改模型后,我们可以使用以下命令来生成迁移文件:

python manage.py makemigrations

然后,应用迁移来更新数据库:

python manage.py migrate
简洁的数据库操作API

Django ORM提供了一个非常简洁的API来操作数据库。我们可以像使用Python列表一样使用QuerySets。

# 获取所有的咒语
spells = Spell.objects.all()

# 添加一个新的咒语
new_spell = Spell(name="Expelliarmus", description="Disarms the target.", is_dark_arts=False)
new_spell.save()

# 更新咒语
spell_to_update = Spell.objects.get(name="Expelliarmus")
spell_to_update.description = "Disarms the target with a flash of light."
spell_to_update.save()

# 删除咒语
spell_to_delete = Spell.objects.get(name="Expelliarmus")
spell_to_delete.delete()

5.3 高级查询与聚合函数

QuerySet的高级用法

Django的QuerySets提供了许多强大的方法来进行高级查询。

# 获取所有的黑魔法咒语
dark_spells = Spell.objects.filter(is_dark_arts=True)

# 获取咒语名称按字母顺序排序的列表
sorted_spells = Spell.objects.order_by('name')
聚合与分组功能

Django ORM还支持聚合和分组功能,这让我们能够执行更复杂的数据库操作。

from django.db.models import Count

# 统计每个类型的咒语数量
spell_counts = Spell.objects.values('is_dark_arts').annotate(total=Count('id'))
for spell_count in spell_counts:
    print(f"{spell_count['is_dark_arts']} spells: {spell_count['total']}")

通过这一章节,我们学习了如何在Django项目中配置数据库,定义模型,以及如何使用Django ORM进行数据库操作。Django的ORM就像是一个强大的魔法工具箱,让我们能够轻松地管理和操作数据。下一章,我们将探索异步数据库交互,这将使我们的数据库操作更加高效和快速。准备好了吗?让我们继续我们的魔法之旅,进入异步编程的神秘领域!
在这里插入图片描述

6. 小结

嗨,大家好!今天我们今天聊了一个特别酷炫的话题——Python数据库交互。这不仅仅是技术层面的交流,更像是一场魔法冒险,阿佑和大家一起探索了如何用Python施展数据库的异步魔法。下面就来简要回顾下些重点步骤吧!

首先,我们得明白数据库在现代应用中扮演的角色。想象一下,数据库就像是一本魔法书,里面记录着无数的咒语和魔法。无论是在线购物平台、社交媒体还是企业资源规划系统,数据库都是它们强大的后盾,存储着海量的数据,让这些系统能够快速、准确地响应用户的需求。

接下来,让我们看看Python在这场魔法中的作用。Python,这个简洁、易学且功能强大的编程语言,当它与数据库结合时,就像魔法师找到了他的魔杖。Python进行数据库交互,可以让开发者轻松地与数据库进行沟通,执行各种数据操作,构建出功能强大的应用程序。

在这场魔法之旅的起点,我们先来了解一些基础概念。数据库可以分为关系型和非关系型两种,关系型数据库就像是传统的图书馆,书籍按照严格的分类系统排列;而非关系型数据库则更加自由灵活,可以存储各种格式的数据。SQL语言则是魔法师与图书馆沟通的语言,它允许魔法师查询、更新、插入和删除图书馆中的书籍(数据)。

随着Python魔法师们对效率的追求,DB-API和ORM技术应运而生。DB-API是一个简单的接口,允许Python与数据库进行基本的交互,而ORM则像是一个高级的魔法,它允许魔法师用Python代码来操作数据库,而不需要编写复杂的SQL语句。

在实战中,我们以SQLite为例,学习了如何使用DB-API连接数据库、执行SQL查询与事务处理,以及参数化查询与错误处理。这就像是学会了如何使用基础的魔法咒语,为进一步探索更高级的魔法打下了基础。

SQLAlchemy作为Python中一个强大的ORM工具,让我们的操作变得更加强大和灵活。通过Engine与Session管理,以及使用declarative_base定义数据模型,我们可以轻松地进行CRUD操作,并探索了关系与关联表、查询表达式与过滤条件等高级特性。

当然,提到数据库交互,我们不能不提Django ORM。Django的ORM就像是一个全功能的魔法塔,让我们的数据库操作变得既简单又强大。在Django中,我们学习了如何设置数据库连接、定义模型,以及使用Django ORM进行数据库操作,包括自动化的数据库迁移和简洁的数据库操作API。

最后,我们即将进入异步编程的神秘领域,学习如何同时施展多个咒语而不需等待。这将使我们的数据库操作更加高效和快速,就像魔法师在施展多个魔法时,能够同时控制而不混乱。

总的来说,这场Python数据库交互的魔法之旅既充满挑战又充满乐趣。我们从基础概念学起,一步步掌握了DB-API、SQLAlchemy和Django ORM等强大的工具,最终将进入异步编程的新世界。

准备好了吗?让我们拿起魔杖,继续我们的魔法冒险,探索更多的未知领域吧!
我是阿佑,一个专注于把晦涩的技术讲得有趣的中二青年,欢迎持续关注!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024广东省赛 G.Menji 和 gcd

题目 #include <bits/stdc.h> using namespace std; #define int long long #define pb push_back #define fi first #define se second #define lson p << 1 #define rson p << 1 | 1 #define ll long long const int maxn 1e6 5, inf 1e12, maxm 4e4 …

脑机接口:是现代医学的外挂,更是瘫痪病人的豪赌

5 月 17 日&#xff0c;马斯克公开表示&#xff0c;继今年年初首次成功将大脑芯片植入患者大脑后&#xff0c;Neuralink 正在寻找第二位受试者接受这项手术。 5 月 20 日&#xff0c;美国食品药品监督管理局 (FDA) 批准了马斯克的 Neuralink 公司为第二位患者植入脑芯片&#…

超详细介绍基于微调 Faster R-CNN实现海上航拍图像中检测小物体-含源码与数据集免费下载

在航拍图像中检测小物体,尤其是对于海上救援等关键应用而言,是一项独特的挑战。及时检测水中的人可能意味着生死之间的差别。我们的研究重点是微调 Faster R-CNN(一种强大的两阶段物体检测器),以满足这一重要需求。 我们研究的核心是SeaDroneSee 数据集,这是一组重要的图…

Springboot项目搭建 jdk1.8

1.idea创建项目 2.项目配置 maven 编辑项目编码 删除无用文件 修改配置文件后缀&#xff0c;设置数据库 spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl:jdbc:mysql://localhost:3306/honey2024?useSSLfalse&useUnicodetrue&characterEncodingUT…

随手记:多行文本域存数据有换行,回显数据换行展示

1.在新增的时候存储数据 <el-input type"textarea"v-model"XXXX"></el-input> 2.详情页返回的数据&#xff1a; replace一顿操作确实复杂 最快的方法直接写个样式:style"white-space: pre-line" 即可行内或者class样式都可以 …

windows 下载redis (通过redis-server.exe启动服务)

下载链接&#xff1a; https://github.com/MicrosoftArchive/redis/releases 启动&#xff1a; 查看&#xff1a; 人工智能学习网站 https://chat.xutongbao.top

在项目中集成Web端数据库操作:推荐工具一览

在项目中集成Web端数据库操作&#xff1a;推荐工具一览 博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍…

Excel快速判断大量身份证性别,VBS代码

身份证判断性别的原理就是,身份证倒数第二位是单数表示是男的,单数是女的 可以用IF公式来判断,但是需要下拉,如果几百上千条数据还好,要是上万就不好拉取了,如果数据太多,可以用VBA代码判断 IF(MOD(VALUE(MID(A1,17,1)),2)0,"女","男") 原理:MID(A1,17,1…

【408真题】2009-24

“接”是针对题目进行必要的分析&#xff0c;比较简略&#xff1b; “化”是对题目中所涉及到的知识点进行详细解释&#xff1b; “发”是对此题型的解题套路总结&#xff0c;并结合历年真题或者典型例题进行运用。 涉及到的知识全部来源于王道各科教材&#xff08;2025版&…

TokenInsight: Covalent SDK、网络及数据可用性解决方案评估报告

摘要 Covalent 是一个区块链长期数据可用性解决方案&#xff0c;提供结构化的链上数据 API&#xff0c;允许开发者访问超过 225 个区块链的全面结构化链上数据。TokenInsight 根据标准化评级方法&#xff0c;从六个维度对 Covalent 进行了评估。 技术和安全 Covalent 自 201…

【学习Day1】计算机基础

✍&#x1f3fb;记录学习过程中的输出&#xff0c;坚持每天学习一点点~ ❤️希望能给大家提供帮助~欢迎点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;指点&#x1f64f; 1.1 中央处理单元CPU 中央处理器&#xff08;CPU&#xff0c;central processing unit&…

著名开源软件Greenplum突然关闭GitHub源码,数据仓库选型带来新变数

今天一早看见新闻&#xff0c;著名的开源数据仓库Greenplum不能访问了&#xff0c;非常吃惊&#xff0c;因为小编昨天晚上还可以从github下载编译Greenplum7.1的源码。早上登录到Greenplum的github主页&#xff0c;已经是"人去楼空"的404了。 目前Greenplum官网和Twi…

Ant Design 动态增减form表单,第二三项根据第一项选中内容动态展示内容

效果图&#xff1a; 选中第一项下拉框&#xff0c;第二第三项展示 点击添加条件&#xff0c;第二条仍然只展示第一项select框 后端返回数据格式&#xff1a; ruleList:[{name:通话时长,key:TALK_TIME,type&#xff1a;’INT‘,unitName:秒,operaObj:[{name:>,value:>…

多输入多输出 | MATLAB实现BiTCN(双向时间卷积神经网络)多输入多输出预测

多输入多输出 | MATLAB实现BiTCN(双向时间卷积神经网络)多输入多输出预测 目录 多输入多输出 | MATLAB实现BiTCN(双向时间卷积神经网络)多输入多输出预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Matlab实现BiTCN双向时间卷积神经网络多输入多输出预测 1.data为数据…

HNU-计算机体系结构-实验1-RISC-V流水线

计算机体系结构 实验1 计科210X 甘晴void 202108010XXX 1 实验目的 参考提供为了更好的理解RISC-V&#xff0c;通过学习RV32I Core的设计图&#xff0c;理解每条指令的数据流和控制信号&#xff0c;为之后指令流水线及乱序发射实验打下基础。 参考资料&#xff1a; RISC-…

13种即插即用涨点模块分享!含注意力机制、卷积变体、Transformer变体

朋友们&#xff0c;你们想发paper的时候有没有被创新点、改模型、改代码折磨过&#xff1f;今天我想分享一个前期又快又省事的方法&#x1f606; 就是用即插即用的模块“缝合”&#xff0c;加入自己的想法快速搭积木炼丹。 这种方法可以简化模型设计&#xff0c;减少冗余工作…

MySQL 数据表的基本操作

文章目录 【 1. MySQL 创建数据表 】【 2. MySQL 查看表 】2.1 DESCRIBE/DESC 以表格的形式展示表2.2 SHOW CREATE TABLE 以SQL语句的形式展示表 【 3. 修改数据表 】3.1 修改表名3.2 修改表字符集3.3 添加字段在末尾添加字段在开头添加字段在中间添加字段 3.3 修改/删除字段修…

【java-数据结构19-队列的模拟实现】

上篇文章&#xff0c;小编已经带大家一起认识了队列&#xff0c;并且对队列的方法进行调用测试&#xff0c;下面我们将模拟实现一个队列&#xff0c;话不多说&#xff0c;上正文~ 1.队列的模拟实现 队列的实现方法和链表的实现方式一模一样&#xff0c;这里我们首选双链表&…

MT2075 礼物

思路&#xff1a; x,y为质数&#xff0c;若x2,y3&#xff0c;则xy的最小公倍数6既不能给A也不能给B。 所以假设共有V个数&#xff0c;在1-V中&#xff0c;可以选的个数为&#xff1a;V-⌊V/(x*y)⌋ 个。&#xff08;⌊V/(x*y)⌋为V个数中有多少个xy的公倍数&#xff09; 所以…

股票量化交易上手,一个特别简单却长期可用的交易策略,官方接口

股票实现程序化自动化交易的三个基础&#xff1a;获取数据、执行交易、查询账户。 以后说到策略示例的时候就不介绍接口的基础使用方法了&#xff0c;随便一个策略把过程写出来都会很啰嗦&#xff0c;尽量压缩内容吧&#xff0c;这些内容是面向新手的&#xff0c;大佬们忽略细节…