当前位置: 首页 > news >正文

MySQL: ALTER

正文

在数据库管理系统(DBMS)中,DDL(Data Definition Language)、DCL(Data Control Language)、和 DML(Data Manipulation Language)是三种主要的SQL(Structured Query Language)语句类型,它们各自负责数据库的不同方面。

  1. DDL(Data Definition Language):数据定义语言,用于定义或修改数据库的结构。它主要包括以下命令:
    • CREATE:用于创建新的数据库、表、索引、视图等对象。
    • ALTER:用于修改现有数据库对象的结构,如添加、删除或修改表中的列。
    • DROP:用于删除整个数据库、表、索引、视图等对象。
    • TRUNCATE:用于删除表中的所有数据,但不删除表本身。
    • COMMENT:用于给数据库、表、列等添加注释。
    • RENAME:用于重命名数据库中的对象,如表或索引。
  2. DCL(Data Control Language):数据控制语言,用于定义数据库、表、或字段的访问权限和安全级别。它主要包括以下命令:
    • GRANT:用于授予用户或角色对数据库对象的访问权限。
    • REVOKE:用于撤销之前通过GRANT命令授予的权限。
  3. 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';

但是,如果你想要在添加多个列的同时,基于某些逻辑或条件为这些新列填充不同的值(即,不是统一的默认值),那么你需要分别进行:

  1. 使用 ALTER TABLE ... ADD COLUMN 语句添加列。
  2. 使用 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 结构,使得数据操作和预处理…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了:一行…...

【Java学习笔记】Arrays类

Arrays 类 1. 导入包:import java.util.Arrays 2. 常用方法一览表 方法描述Arrays.toString()返回数组的字符串形式Arrays.sort()排序(自然排序和定制排序)Arrays.binarySearch()通过二分搜索法进行查找(前提:数组是…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵,其中每行,每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid,其中有多少个 3 3 的 “幻方” 子矩阵&am…...

AI病理诊断七剑下天山,医疗未来触手可及

一、病理诊断困局:刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断",医生需通过显微镜观察组织切片,在细胞迷宫中捕捉癌变信号。某省病理质控报告显示,基层医院误诊率达12%-15%,专家会诊…...

【VLNs篇】07:NavRL—在动态环境中学习安全飞行

项目内容论文标题NavRL: 在动态环境中学习安全飞行 (NavRL: Learning Safe Flight in Dynamic Environments)核心问题解决无人机在包含静态和动态障碍物的复杂环境中进行安全、高效自主导航的挑战,克服传统方法和现有强化学习方法的局限性。核心算法基于近端策略优化…...

JS手写代码篇----使用Promise封装AJAX请求

15、使用Promise封装AJAX请求 promise就有reject和resolve了,就不必写成功和失败的回调函数了 const BASEURL ./手写ajax/test.jsonfunction promiseAjax() {return new Promise((resolve, reject) > {const xhr new XMLHttpRequest();xhr.open("get&quo…...

MySQL 8.0 事务全面讲解

以下是一个结合两次回答的 MySQL 8.0 事务全面讲解,涵盖了事务的核心概念、操作示例、失败回滚、隔离级别、事务性 DDL 和 XA 事务等内容,并修正了查看隔离级别的命令。 MySQL 8.0 事务全面讲解 一、事务的核心概念(ACID) 事务是…...

jmeter聚合报告中参数详解

sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample(样本数) 表示测试中发送的请求数量,即测试执行了多少次请求。 单位,以个或者次数表示。 示例:…...

Caliper 负载(Workload)详细解析

Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...

沙箱虚拟化技术虚拟机容器之间的关系详解

问题 沙箱、虚拟化、容器三者分开一一介绍的话我知道他们各自都是什么东西,但是如果把三者放在一起,它们之间到底什么关系?又有什么联系呢?我不是很明白!!! 就比如说: 沙箱&#…...