MySQL: ALTER
正文
在数据库管理系统(DBMS)中,DDL(Data Definition Language)、DCL(Data Control Language)、和 DML(Data Manipulation Language)是三种主要的SQL(Structured Query Language)语句类型,它们各自负责数据库的不同方面。
- DDL(Data Definition Language):数据定义语言,用于定义或修改数据库的结构。它主要包括以下命令:
CREATE:用于创建新的数据库、表、索引、视图等对象。ALTER:用于修改现有数据库对象的结构,如添加、删除或修改表中的列。DROP:用于删除整个数据库、表、索引、视图等对象。TRUNCATE:用于删除表中的所有数据,但不删除表本身。COMMENT:用于给数据库、表、列等添加注释。RENAME:用于重命名数据库中的对象,如表或索引。
- DCL(Data Control Language):数据控制语言,用于定义数据库、表、或字段的访问权限和安全级别。它主要包括以下命令:
GRANT:用于授予用户或角色对数据库对象的访问权限。REVOKE:用于撤销之前通过GRANT命令授予的权限。
- DML(Data Manipulation Language):数据操纵语言,用于检索、插入、更新和删除数据库中的数据。它主要包括以下命令:
SELECT:用于从数据库表中检索数据。INSERT:用于向数据库表中插入新的数据行。UPDATE:用于修改表中的数据。DELETE:用于从表中删除数据行。
这三种语言共同构成了SQL的核心,使得用户能够高效地管理数据库中的数据。在实际应用中,DDL、DCL和DML语句的使用是密不可分的,它们相互配合,共同完成了数据库的创建、维护和管理等任务。
ALTER TABLE
在 MySQL 中,ALTER TABLE 语句用于修改表结构,但它本身并不直接支持在添加列的同时给这些新列填充多个具体的值(即,不是像 INSERT 语句那样插入数据行)。ALTER TABLE ... ADD COLUMN 只是用于添加新的列到表中,而不涉及填充数据。
如果你想要为新添加的列填充数据,你需要在添加列之后使用 UPDATE 语句来更新表中的行,或者对于新插入的行,在 INSERT 语句中指定这些列的值。
然而,如果你的意图是在添加列时给表中已存在的每一行都设置一个默认值,那么你只需要在 ADD COLUMN 语句中指定该默认值即可。这样,MySQL 会自动为新列中的每一行应用这个默认值。
例如,如果你想要给 employees 表添加一个新列 hire_date,并且想要为表中已存在的每一行都设置 hire_date 的默认值为 '1970-01-01',你可以这样做:
ALTER TABLE employees
ADD COLUMN hire_date DATE DEFAULT '1970-01-01';
但是,如果你想要在添加多个列的同时,基于某些逻辑或条件为这些新列填充不同的值(即,不是统一的默认值),那么你需要分别进行:
- 使用
ALTER TABLE ... ADD COLUMN语句添加列。 - 使用
UPDATE语句基于需要填充的逻辑或条件更新这些新列的值。
例如,如果你还想要添加一个 salary 列,并根据某种逻辑(比如基于员工的职位或其他属性)为现有员工设置不同的薪资,你需要:
-- 添加新列
ALTER TABLE employees
ADD COLUMN salary DECIMAL(10, 2); -- 更新新列的值
-- 假设这里有一个简单的逻辑:所有员工薪资设为 50000
UPDATE employees
SET salary = 50000; -- 或者,基于更复杂的逻辑更新薪资
-- 例如,基于职位设置薪资
UPDATE employees
SET salary = CASE WHEN position = 'Engineer' THEN 60000 WHEN position = 'Manager' THEN 80000 ELSE 50000
END;
注意,UPDATE 语句中的条件(如 position = 'Engineer')应该基于你表中实际存在的列和值来编写。
ADD COLUMN 多列
在 MySQL 中,ALTER TABLE ... ADD COLUMN 语句通常用于一次添加一个列。但是,如果你想要一次性添加多个列,你需要在 ALTER TABLE 语句中多次使用 ADD COLUMN,每个新列之间用逗号分隔,但每个 ADD COLUMN 都需要单独的一行(尽管在某些 SQL 方言或工具中可能允许在一行内使用多个 ADD COLUMN,但在 MySQL 的标准语法中,这是不推荐的)。
下面是一个在 ALTER TABLE 语句中一次性添加多个列的示例:
ALTER TABLE employees
ADD COLUMN column1_name datatype1 [constraint1],
ADD COLUMN column2_name datatype2 [constraint2],
ADD COLUMN column3_name datatype3 [constraint3];
注意,每个 ADD COLUMN 子句都是独立的,并且以逗号分隔(尽管在 ADD COLUMN 之间实际上不需要逗号,因为它们是单独的语句,但出于清晰和一致性的目的,在列出多个时添加逗号是一个好习惯)。然而,在 MySQL 中,由于语法限制,每个 ADD COLUMN 通常需要放在单独的行上。
下面是一个具体的例子
ALTER TABLE employees
ADD COLUMN email VARCHAR(255) NOT NULL UNIQUE,
ADD COLUMN phone_number VARCHAR(20),
ADD COLUMN hire_date DATE DEFAULT '1970-01-01';
在这个例子中,employees 表被添加了三个新列:
email列,数据类型为VARCHAR(255),不允许空值(NOT NULL),并且所有值都必须是唯一的(UNIQUE)。phone_number列,数据类型为VARCHAR(20),没有额外的约束(尽管它可能应该有一个NOT NULL约束,具体取决于你的需求)。hire_date列,数据类型为DATE,默认值为'1970-01-01'(这可能不是最佳实践,因为1970-01-01通常是 UNIX 时间戳的起点,你可能想要一个更有意义的默认值,或者确保在插入新记录时提供具体的日期)。
--end--
相关文章:
MySQL: ALTER
正文 在数据库管理系统(DBMS)中,DDL(Data Definition Language)、DCL(Data Control Language)、和 DML(Data Manipulation Language)是三种主要的SQL(Struct…...
微前端技术预研 - bit初体验
1.关于什么是微前端以及微前端的发展, 当前主流框架以及实现技术等,可参考这篇总结(非常全面), 微前端总结:目录详见下图 本文内容主要针对bit框架的实时思路以及具体使用。 1.什么是Bit? Bit 是可组合软件的构建…...
对象关系映射---ORM
一、什么是ORM? ORM(Object Relational Mapping),即对象关系映射,是一种程序设计技术,用于在面向对象编程语言中实现对象和关系型数据库之间的映射。 二、ORM是干什么的? ORM 的主要目的是简…...
Django REST Framework(十七)Authentication
1.认证Authentication 在 Django REST framework (DRF) 中,可以在配置文件中配置全局默认的认证方案。常见的认证方式包括 cookie、session、和 token。DRF 提供了灵活的认证机制,可以在全局配置文件中设置默认认证方式,也可以在具体的视图类…...
FPGA开发——数码管的使用
一、概述 在我们的日常开发中,数字显示的领域中用得最多的就是数码管,这篇文章也是围绕数码管的静态显示和动态显示进行一个讲解。 1、理论 (1)数码管原理图 在对数码管进行相关控制时,其实就是对于8段发光二极管和…...
什么是网络安全等级保护测评服务?
等保测评 依据国家网络安全等级保护制度规定,按照有关管理规范和技术标准,对非涉及国家秘密的网络安全等级保护状况进行检测评估。定级协助 根据等级保护对象在国家安全、经济建设、社会生活中的重要程度,以及一旦遭到破坏、丧失功能或者数据…...
基于深度学习的多模态情感分析
基于深度学习的多模态情感分析是一个结合不同类型数据(如文本、图像、音频等)来检测和分析情感的领域。它利用深度学习技术来处理和融合多模态信息,从而提高情感分析的准确性和鲁棒性。以下是对这一领域的详细介绍: 1. **多模态情…...
Glove-词向量
文章目录 共现矩阵共线概率共线概率比词向量训练总结词向量存在的问题 上一篇文章词的向量化介绍了词的向量化,词向量的训练方式可以基于语言模型、基于窗口的CBOW和SKipGram的这几种方法。今天介绍的Glove也是一种训练词向量的一种方法,他是基于共现概率…...
Plugin ‘mysql_native_password‘ is not loaded`
Plugin mysql_native_password is not loaded mysql_native_password介绍1. 使用默认的认证插件2. 修改 my.cnf 或 my.ini 配置文件3. 加载插件(如果确实没有加载)4. 重新安装或检查 MySQL 版本 遇到错误 ERROR 1524 (HY000): Plugin mysql_native_passw…...
Hive数据类型
原生数据类型 准备数据 查看表信息 加载数据 查看数据 复杂数据类型-数组 准备数据 查看数据 优化 复杂数据类型-map 准备数据 查看数据 复杂数据类型-默认分隔符 准备数据 查看数据 原生数据类型 准备数据 -- 1 建库 drop database if exists db_1 cascade;…...
OSI七层网络模型:构建网络通信的基石
在计算机网络领域,OSI(Open Systems Interconnection)七层模型是理解网络通信过程的关键框架。该模型将网络通信过程细分为七个层次,每一层都有其特定的功能和职责,共同协作完成数据从发送端到接收端的传输。接下来&am…...
MSYS2下载安装和使用
Minimalist GNU(POSIX)system on Windows,Windows下的GNU环境。 目录 1. 安装 2. pacman命令 3. 配置vim 4. 一些使用示例 4.1 编译代码 4.2 SSH登录远程服务器 1. 安装 官网下载:https://www.msys2.org/ 双击.exe文件&am…...
机器学习中的决策树算法——从理论到实践完整指南
决策树在机器学习中的应用与原理 1. 介绍1.1 定义和基本概念1.2 决策树在机器学习中的角色和重要性 2. 决策树的结构2.1 节点、分支、叶子节点的定义和功能2.1.1 节点2.1.2 分支2.1.3 叶子节点 2.2 树的深度和宽度的影响2.2.1 树的深度2.2.2 树的宽度 3. 决策树的构建方法3.1 基…...
FFplay介绍及命令使用指南
😎 作者介绍:欢迎来到我的主页👈,我是程序员行者孙,一个热爱分享技术的制能工人。计算机本硕,人工制能研究生。公众号:AI Sun(领取大厂面经等资料),欢迎加我的…...
php实现动态登录
简介: 效果:通过前端页面的注册,通过MD5将密码加密,发送到数据库,通过验证数据库的内容实现登录,以及各种保证安全的措施 实验环境:phphtmlcssmysql数据表,使用html css设计注册&a…...
Servlet2-HTTP协议、HttpServletRequest类、HttpServletResponse类
目录 HTTP协议 什么是HTTP协议 HTTP协议的特点 请求的HTTP协议格式 GET请求 POST请求 常用的请求头说明 哪些是GET请求,哪些是POST请求 响应的HTTP协议格式 常见的响应码说明 MIME类型说明 HttpServletRequest类 作用 常用方法 如何获取请求参数 po…...
探索数据的内在世界:sklearn中分层特征聚类标签的可视化技术
探索数据的内在世界:sklearn中分层特征聚类标签的可视化技术 在机器学习中,聚类是一种探索数据结构的强大工具。对于具有分层特征的数据,如文本、时间序列或分类标签,聚类结果的可视化可以提供深入的洞见。本文将详细介绍如何在s…...
airtest定位方法
airtest定位方法 最近遇到一个比较新颖的airtest方法,分享给大家。一键三连; airtest是一款用于自动化测试的Python库,被广泛应用于移动应用和游戏的测试中。在进行自动化测试时,定位元素是非常重要的一步,因为只有准…...
排列组合 n*(n-1)*(n-m+1)
n*(n-1)*(n-m1)/m! --# 组合 n*(n-1)*(n-m1)/m! local function get_combinations(n,m) c 1 c0 1 for i 1,m do c c*(n-i1) c c/i end return math.floor(c) end print(get_combinations(10,6)) 打印出来为:210...
Python面试整理-数据处理和分析
在Python中,数据处理和分析是一项非常重要的应用,得益于丰富的第三方库和工具,Python已经成为数据科学家和分析师的首选语言之一。以下是进行数据处理和分析时常用的工具和方法: 1. 数据处理 a. Pandas ● 功能: Pandas 提供了强大的 DataFrame 结构,使得数据操作和预处理…...
二极管单向导电性的秘密:为什么你的电路不工作?可能是二极管接反了!
二极管单向导电性的秘密:为什么你的电路不工作?可能是二极管接反了! 刚接触电子电路的朋友们,一定遇到过这样的困惑:明明按照电路图连接了所有元件,电源也接通了,可电路就是不工作。这时候&…...
EPWM模块影子寄存器的加载机制与应用场景解析
1. EPWM模块影子寄存器基础概念 第一次接触EPWM模块的影子寄存器时,我也被这个"影子"的概念绕晕了。后来在实际项目中调试电机控制才发现,这个机制简直是PWM波形控制的"安全气囊"。简单来说,影子寄存器就是活动寄存器的&…...
03 MongoDB文档的各种增加、更新、删除操作总结
更多内容请见: 《深入掌握MongoDB数据库》 - 专栏介绍和目录 一. 插入文档 注意: 在 MongoDB 中,直接插入内容会自动创建集合! 1.1 使用insert()方法 语法格式: db.COLLECTION_NAME.insert(document) 说明: 若插入的数据主键已经存在,则会抛 org.springframework.dao.Du…...
掌握LSLib:解锁《神界原罪》与《博德之门3》MOD制作的神器
掌握LSLib:解锁《神界原罪》与《博德之门3》MOD制作的神器 【免费下载链接】lslib Tools for manipulating Divinity Original Sin and Baldurs Gate 3 files 项目地址: https://gitcode.com/gh_mirrors/ls/lslib LSLib是一个功能强大的开源工具集࿰…...
传统文化与现代AI结合:Guohua Diffusion国风绘画商业应用案例
传统文化与现代AI结合:Guohua Diffusion国风绘画商业应用案例 1. 国风绘画生成工具概述 Guohua Diffusion是一款专为国风绘画设计的本地生成工具,基于原生Guohua-Diffusion模型开发。这款工具完美融合了中国传统绘画艺术与现代AI技术,为艺术…...
OEC-turbo变废为宝:从吃灰PCDN盒子到家庭服务器,Armbian/OpenWrt刷机实战记录
OEC-turbo硬件改造指南:从闲置PCDN设备到全能家庭服务器 手上闲置的OEC-turbo盒子除了吃灰还能做什么?这款搭载RK3568芯片的设备实际上是一块被低估的硬件宝藏。相比市面上热门的斐讯N1等矿渣设备,OEC-turbo在处理器性能、内存配置和扩展性方…...
深入解析Triton Server的Backend插件机制与自定义开发实践
1. Triton Server与Backend插件机制概述 第一次接触Triton Server时,最让我困惑的就是它的Backend机制。简单来说,Triton就像一个万能插座,而各种Backend就是不同标准的插头。比如你用PyTorch训练了个模型,Triton的pytorch_backen…...
Polars 2.0大规模清洗崩溃全解析:内存溢出、Schema冲突、LazyFrame中断——3类高频致命报错的5分钟修复方案
第一章:Polars 2.0大规模清洗崩溃全解析:内存溢出、Schema冲突、LazyFrame中断——3类高频致命报错的5分钟修复方案 当处理TB级结构化数据时,Polars 2.0的LazyFrame虽带来性能飞跃,却也因底层执行引擎变更放大了三类典型崩溃风险。…...
Z-Image-ComfyUI场景应用:为社交媒体快速生成配图,提升内容创作效率
Z-Image-ComfyUI场景应用:为社交媒体快速生成配图,提升内容创作效率 1. 社交媒体内容创作的痛点与解决方案 每天运营社交媒体账号时,你是否也面临这样的困境:精心撰写的文案已经完成,却卡在配图制作环节?…...
技术Lead:不亲手解决问题,你的位置还稳吗?
做到技术Lead这个位置,很多人开始纠结一件事——到底该不该自己动手?技术Lead的尴尬,其实很具体比如前端设计阶段,团队在讨论一个时序收敛问题,工程师说某条路径的slack是-0.3ns,建议加pipeline。这时候Lea…...
