🔥个人主页:寻星探路

🎬作者简介:Java研发方向学习者

📖个人专栏:《从青铜到王者,就差这讲数据结构!!!》、 《JAVA(SE)----如此简单!!!》、《数据库那些事!!!》

⭐️人生格言:没有人生来就会编程,但我生来倔强!!!


目录

一、什么是数据库约束

二、约束类型

1、not null空约束

1.1创建⼀个学生表

1.2此时需要约束学生名的列不能为null

1.3查看表结构

2、default默认值约束

2.1重构学生表

2.2重构学生表

2.3查看表结构

3、unique唯一约束

3.1重构学生表

3.2重构学生表

3.3查看表结构


一、什么是数据库约束

        数据库约束是指对数据库表中的数据所施加的规则或条件,用于确保数据的准确性和可靠性。这些约束可以是基于数据类型、值范围、唯⼀性、非空等规则,以确保数据的正确性和相容性。

二、约束类型

1、not null空约束

定义表时某列不允许为null时,可以为列添加非空约束。(相当于注册账号时的必填项)

1.1创建⼀个学生表

        学生名为null时,这条记录是不完整的

drop table if exists student;
create table student(id bigint,name varchar(20)
);# 插⼊数据
insert into student values (1, null);# 查询
select * from student;

1.2此时需要约束学生名的列不能为null

drop table if exists student;# 为所有列添加⾮空约束
create table student (id bigint,name varchar(20) NOT NULL
);# 由于name列有⾮空约束,插⼊NULL值时报错
insert into student values (1, null);

# 正常值可以成功插⼊
insert into student values (1, '张三');select * from student;

1.3查看表结构

        NULL列为NO表示值不允许为NULL,YES表示值可以为NULL

desc student;

2、default默认值约束

default约束用于向列中插⼊默认值,如果没有为列设置值,那么会将默认值设置到该列

2.1重构学生表

        新增年龄列

drop table student;# 创建学⽣表,加⼊年龄列
create table student (id bigint,name varchar(20) not null,age int
);

        插入⼀条记录,没有设置默认约束时,不指定年龄的值时列为NULL

insert into student(id, name) values (1, '张三');select * from student;

2.2重构学生表

        为年龄的列加入默认约束

drop table student;# 为年龄列加⼊默认约束
create table student (id bigint,name varchar(20) not null,age int default 18
);

        插入⼀条记录,不指定年龄的值时列使用了默认值

insert into student(id, name) values (1, '张三');select * from student;

2.3查看表结构

        年龄列的默认值为18

desc student;

        当手动明确指年龄列为NULL时列值为NULL

insert into student(id, name, age) values (2, '李四', NULL);

3、unique唯一约束

指定了唯⼀约束的列,该列的值在所有记录中不能重复,如⼀个⼈的身份证号,学生的学号等

3.1重构学生表

        新增学号列

drop table student;# 学号列设置唯⼀约束
create table student (id bigint,name varchar(20) not null,age int DEFAULT 18,sno varchar(10)
);

        不设置唯⼀约束时,学号可以重复

insert into student(id, name, sno) values (1, '张三', '100001');insert into student(id, name, sno) values (2, '李四', '100001');select * from student;

3.2重构学生表

        为学号列设置唯⼀约束

drop table student;create table student (id bigint,name varchar(20) not null,age int DEFAULT 18,sno varchar(10) UNIQUE# 唯⼀约束
);

        插入重复的学号时报错,唯⼀约束生效

insert into student(id, name, sno) values (1, '张三', '100001');

insert into student(id, name, sno) values (2, ' 李四 ', '100001');

select * from student;

3.3查看表结构

        Key列显示UNI表示唯⼀约束

 desc student;

#注:

distinct本来数据库服务器存储的内容中,已经有重复的了。展示给用户的时候,展示的是去重的结果

unique 是存的数据就不能重复(重复的数据存不下去),查询的结果自然也是不重复的

         由于内容较多,会分为多篇讲解,预知后续内容,请看后续博客!!!

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

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

相关文章

知微传感Dkam系列3D相机SDK例程篇:CSharp连接相机及保存数据

序言 写在前面 本人从事机器视觉细分的3D相机行业。编写此系列文章主要目的有: 1、便利他人应用相机,本系列文章包含公司所出售相机的SDK的使用例程及详细注释;2、促进行业发展及交流。 知微传感Dkam系列3D相机可以应用于定位分拣、焊接焊缝提…

[笔记] 系统分析师 第十二章 软件架构设计(分析师主要工作)

文章目录前言12.1 软件架构概述12.1.1 软件架构的意义12.1.2 软件架构的发展史12.2 软件架构建模12.3 软件架构风格12.3.1 软件架构风格概述12.3.2 数据流体系结构风格1.批处理体系结构风格2.管道-过滤体系结构风格12.3.3 调用/返回体系结构风格1.主程序/子程序风格2.面向对象体…

C++---存储周期,作用域,链接性

在C程序设计中,变量的行为不仅由其类型决定,还由存储周期(变量在内存中存在的时间)、作用域(变量可被访问的代码范围)和链接性(变量在多文件程序中的可见性)共同约束。 一、存储周期…

基于Python的商品爬取与可视化系统

本系统是基于Python的商品数据爬取与价格分析可视化系统,集成了数据爬取、数据存储、数据展示和可视化分析等功能。下面介绍一下系统主要功能和技术栈。一、主要功能:1、数据爬取功能 支持淘宝美妆商品数据爬取 可配置搜索关键词和爬取页数 实时显示爬取…

联邦学习过程中,了解清楚影响准确率的因素有哪些也很重要

影响模型准确率的因素有很多,下面是一些主要的因素,它们可以从数据、模型设计、训练策略以及超参数等多个层面来考虑。1. 学习率作用:学习率直接影响模型的训练速度、稳定性和最终表现。过高的学习率可能导致模型不收敛或收敛不稳定&#xff…

C# WPF中使用System.Management.Automation类调用Powershell报错解决办法

在WPF开发中,需要使用powershell进行自动化管理,以下为开发环境 1、.NET framework 4.7.2 2、VS2019 社区版 使用System.Management.Automation类 遇到的问题: 需要引用 System.Management.Automation类,但是在使用using指令时无法…

从 Pump.fun「直播」看热点币的生与死

在加密市场里,热点就是流量,流量就是价值。最近,Solana 生态的 Pump.fun 推出了「直播」板块,让发币这件事变得像看秀一样:一个个新币在链上实时登场,社区即时互动,玩家实时下注。这种形式不仅带…

图灵完备性:计算理论的基石与无限可能

本文由「大千AI助手」原创发布,专注用真话讲AI,回归技术本质。拒绝神话或妖魔化。搜索「大千AI助手」关注我,一起撕掉过度包装,学习真实的AI技术! 1 图灵完备性的基本概念 图灵完备性(Turing completeness…

HarmonyOS 5.0应用开发——V2装饰器@once的使用

【高心星出品】 文章目录V2装饰器once的使用概念一、核心作用与规则二、适用场景案例V2装饰器once的使用 概念 在鸿蒙ArkTS开发中,Once装饰器用于实现子组件仅接受父组件传递的初始值,后续父组件数据变化不再同步至子组件。以下是其核心要点&#xff1…

跨域请求:解决方案

一、跨域核心概念:同源策略与跨域定义 跨域问题的根源是浏览器的 同源策略(Same-Origin Policy),这是浏览器为保护用户数据安全而设置的核心安全限制。 1. 什么是 “同源”? “同源” 指的是两个 URL 的 协议、域名…

前端形态与样式风格:从古典到现代的视觉语言演进

目录前端形态与样式风格:从古典到现代的视觉语言演进概述1. 前端形态的演进:四种核心范式1.1 古典范式:语义化HTML与CSS1.2 组件化范式:模块化与复用1.3 响应式范式:多端适配1.4 动态范式:状态驱动视图2. 样…

用户系统从0到1:登录、权限、积分一网打尽

👤 用户系统从0到1:登录、权限、积分一网打尽 副标题:Flask-Login 多级权限 积分会员系统实战 项目原型:https://madechango.com 难度等级:⭐⭐⭐☆☆ 预计阅读时间:20分钟 🎯 引子&#xff1…

Java 大视界 -- Java 大数据在智能安防视频监控系统中的视频内容理解与智能预警升级

Java 大视界 -- Java 大数据在智能安防视频监控系统中的视频内容理解与智能预警升级引言:正文:一、传统安防监控的 “三重困局”:看不全、看不懂、反应慢1.1 人工盯屏 “力不从心”1.1.1 摄像头密度与人力的矛盾1.1.2 录像调阅 “马后炮”1.2…

OpenHarmony包管理子系统核心源码深度解读:从BundleManager到AMS,彻底打通应用安装、卸载与沙箱机制全链路

目录 架构概览 核心组件详解 包安装流程分析 包卸载流程分析 包更新流程分析 包信息存储机制 Launcher界面管控 开机默认系统应用安装机制<

简单聊聊神经网络中的反向传播

参考文章&#xff1a; 一文弄懂神经网络中的反向传播法——BackPropagation - Charlotte77 - 博客园 反向传播求偏导原理简单理解_反向传播偏导-CSDN博客 这篇文章是笔者在读完上述两篇参考文章后的整理或者说按照自己的理解进行的一些补充&#xff0c;强烈推荐先阅读上述两篇文…

JSP自驾游管理系统46u2v--(程序+源码+数据库+调试部署+开发环境)

本系统&#xff08;程序源码数据库调试部署开发环境&#xff09;带论文文档1万字以上&#xff0c;文末可获取&#xff0c;系统界面在最后面。系统程序文件列表开题报告内容一、研究背景与意义 近年来&#xff0c;自驾游因自由度高、个性化强成为国内旅游市场增长最快的领域&…

通过 SQL 快速使用 OceanBase 向量检索学习笔记

背景 AI时代离不开向量数据库&#xff0c;向量数据库简单说就是在数据库中用多维向量存储某类事物的特征&#xff0c;通过公式计算各个向量在空间坐标系中的位置关系&#xff0c;以此来判断事物之间的相似性。相关基础概念如下: ● Embedding ● 距离/相似性度量 ○ Cosine dis…

PromptAD:首次引入提示学习,实现精准工业异常检测,1张正常样本即可超越现有方法

近年来&#xff0c;工业异常检测&#xff08;Anomaly Detection&#xff09;在智能制造、质量监控等领域扮演着越来越重要的角色。传统方法通常依赖大量正常样本进行训练&#xff0c;而在实际生产中&#xff0c;异常样本稀少甚至不存在&#xff0c;能否仅凭少量正常样本就实现精…

算法 --- 字符串

字符串 字符串算法题目主要处理文本的查找、匹配、比较、变换和统计问题&#xff0c;其核心特点是输入数据为字符序列&#xff0c;解题关键在于利用其连续性、前缀性、字典序等特性&#xff0c;并常借助哈希、自动机、指针滑动、动态规划等技巧高效处理。 详细分类型与适用场景…

SpringBoot中 Gzip 压缩的两种开启方式:GeoJSON 瘦身实战

目录 前言 一、GZIP压缩知识简介 1、什么是Gzip 2、Gzip特点 3、Gzip在GIS方面的应用 二、SpringBoot中开启Gzip的方式 1、在SpringBoot中开启Gzip的知识简介 2、SpringBoot中GeoJSON的实例 三、全局开启Gzip实现 1、实现原理 2、实现效果 四、局部约定配置 1、实现…