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

SQL基础 | NOT NULL 约束介绍

在SQL中,NOT NULL是一个约束条件,用于确保列不接受NULL值。

这个约束通常在创建表或修改表时使用,以确保数据的完整性和准确性。

以下是NOT NULL的一些常见用法:

  1. 创建表时指定NOT NULL约束: 当你创建一个新表时,可以在列定义后面添加 NOT NULL来指定该列不能包含 NULL值。
CREATE TABLE customers (
   customer_id INT NOT NULL,
   first_name VARCHAR(50NOT NULL,
   last_name VARCHAR(50NOT NULL,
   email VARCHAR(100)
);

在这个例子中,customer_idfirst_namelast_name列都不能包含NULL值,而email列没有这个约束,所以它可以是NULL

  1. 修改表时添加NOT NULL约束: 如果一个表已经存在,但你想要添加 NOT NULL约束到某个列上,可以使用 ALTER TABLE语句。
ALTER TABLE customers
MODIFY email VARCHAR(100NOT NULL;

这个语句将email列的约束从可为NULL修改为不能为NULL

  1. 在列定义中使用DEFAULT值与NOT NULL: 你可以将 NOT NULLDEFAULT关键字一起使用,为列提供一个默认值。
CREATE TABLE orders (
order_id INT NOT NULL,
customer_id INT NOT NULL,
order_date DATETIME NOT NULL DEFAULT now()
);

在这个例子中,如果用户在插入新订单时没有指定order_date,那么将自动使用当前日期作为默认值。

  1. 在INSERT语句中处理NOT NULL约束: 当你向一个包含 NOT NULL约束的表中插入数据时,必须为这些列提供值。
INSERT INTO orders (order_id, customer_id)
VALUES (1null);

INSERT INTO orders (order_id, customer_id)
VALUES (11);

如果你尝试插入一个缺少 order_id,customer_id 值的记录,SQL将返回错误,因为这些列都有NOT NULL约束。

  1. 在UPDATE语句中处理NOT NULL约束: 即使列具有 NOT NULL约束,你也可以通过 UPDATE语句为这些列设置新值,只要新值不是 NULL
UPDATE customers
SET first_name = 'Jane'
WHERE customer_id = 1;

NOT NULL约束是数据库设计中非常重要的一部分,它帮助确保数据的完整性,防止不完整的数据被存储到数据库中。在设计数据库时,合理地使用NOT NULL约束可以提高数据的可靠性和应用程序的健壮性。

本文由 mdnice 多平台发布

http://www.lryc.cn/news/400183.html

相关文章:

  • C语言 ——— 实用调试技巧(Visual Studio)
  • 音频demo:使用faad2将AAC数据解码出PCM数据
  • 力扣 hot100 -- 多维动态规划
  • [misc]-流量包-wireshark-icmp
  • 探索性数据分析:使用Python与Pandas库实现数据洞察
  • 枚举的高阶用法之枚举里写方法以及注入spring的bean
  • 游戏开发面试题2
  • 华为机试题-单车道汽车通行时间-Java
  • 6-5,web3浏览器链接区块链(react+区块链实战)
  • C# 多态性
  • Visual Studio 安装程序无法执行修复或更新
  • C#与PLC通信——如何设置电脑IP地址
  • Milvus 核心设计(1) ---- 数据一致性的等级及使用场景
  • EasyCVR视频技术:城市电力抢险的“千里眼”,助力抢险可视化
  • 【Wamp】局域网设备访问WampServer | 使用域名访问Wamp | Wamp配置HTTPS
  • 采用自动微分进行模型的训练
  • k8s怎么配置secret呢?
  • 算法篇 滑动窗口 leetcode 长度最小的子数组
  • 数据库作业d8
  • 前后端数据交互设计到的跨域问题
  • 非洲猪瘟监测设备的作用是什么?
  • 移动硬盘损坏无法读取?专业恢复策略全解析
  • 神经网络以及简单的神经网络模型实现
  • java中压缩文件的解析方式(解析文件)
  • 巧用 VScode 网页版 IDE 搭建个人笔记知识库!
  • Jupyter Lab 使用
  • MyBatis where标签内嵌foreach标签查询报错‘缺失右括号‘或‘命令未正确结束‘
  • 重生奇迹MU 群战王牌
  • SpinalHDL之VHDL 和 Verilog 生成
  • c语言中的字符串函数