数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(二).设置主键自增等特点

news2024/11/17 14:39:26

前言        

        在上一节中,主要介绍了 Navicat Premium 17 的使用以及创建一个基础的表格。当时只设置了给数据表补充字段,没有设置给数据表删除字段。现在补充一下。

ALTER TABLE student ADD test int(4);

给名为 student 的数据表添加 test 列,数据类型为 int(4)

 执行新增测试样例代码如下所示: 

执行结果如下所示:

执行测试样例删除命令:

ALTER TABLE 表名 DROP 列名;

删除数据表的指定列

代码执行结果如图所示:

一. 设置自增列

        设置自增列有两种情况:第一种情况是增加一个新的列(属性),并把它设置为自增状态。第二情况是将表中存在的某一列设置为自增。

        在数据表中,自增经常被当做主键,但是自增并不一定是主键。主键:数据库表中用于唯一标识每条记录的一列或一组列。主键在每个数据表中只能存在一个。

1.1 数据表添加自增列

ALTER TABLE student ADD test int(4) PRIMARY KEY AUTO_INCREMENT;

给 student 数据表 添加 test列,并将其设置为主键和自增。

执行完代码,在指定位置刷新如下图所示:

注意在此时如果没有设置主键会报错,在这个软件中自增就需要设置为主键。

1.2 设置数据表某一列为自增

首先执行下列命令删除 test 列,因为一个表中只能存在一个主键。

ALTER TABLE student DROP test;

删除 student 表 test 属性。

命令的输入及解释: 

ALTER TABLE student CHANGE id id int(4) PRIMARY KEY AUTO_INCREMENT;

将 student 表中的 id 设置为主键自增

命令原型:ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [约束];

查看数据信息

SHOW COLUMNS FROM student LIKE 'id';

查看表 student 的 id 属性的信息

  • 列名为“ id”
  • 数据类型为int(4)
  • 允许值为不空(NO)
  • 定义主键(Key 为 PRI)
  • 默认值为NULL(Default列为空)
  • 数据量设置为自增(Extra列为 auto_increment)

二. 设置属性为禁止为空

        设置禁止为空也有两个情况:第一种情况是增加一个新的列(属性),并把它设置为禁止为空状态。第二情况是将表中存在的某一列设置为禁止为空。

2.1 数据表添加禁止为空列

ALTER TABLE student ADD test int(4) NOT NULL;

设置数据表 student 增加 非空列 test

测试是否添加成功

SHOW COLUMNS FROM student LIKE 'test';

2.2 尝试添加为空

先正常添加数据,测试之前代码正确性。

INSERT INTO student (name,sex,age,test) VALUES ('测试','男','19','1');

添加数据

SELECT * FROM student;

查看表中所有的数据

查看表中所有的数据 结果如下,添加成功。

添加第一种错误数据。添加age为空的数据,所以这里说明在代码中不能直接设置为空数据。

INSERT INTO student (name,sex,age,test) VALUES ('测试1','男','','1');

添加数据

添加age为空的数据,所以这里表名在代码中不能直接设置为空数据

添加第二种错误数据。添加位置如下图所示:

  • 第一步双击红色框 student
  • 之后就会弹出黄色框的内容,如果没有自动切换过去,手动点击即可
  • 点击下方绿色加号 
  • 输入完数据之后,点击加号那一列第三个符号“对号”完成输入

只添加属性 test 的内容,可以添加成功。

添加其他四个属性的值,不添加  test  属性,报错。

通过控制变量法可以判断非空已经生效。

2.3 设置数据表某一列为非空

首先执行下列命令删除 test 列,因为我的习惯是测试数据即使删除。

ALTER TABLE student DROP test;

删除 student 表 test 属性。

通过选中测试数据,点击红色区域内的减号,删除数据。

ALTER TABLE student CHANGE name name VARCHAR(20) NOT null;

将 student 表中的 name 设置为非空

命令原型:ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [约束];

        测试过程忽略,测试结果成功。MySQL数据库主键自增长删除后ID存在不连续的问题,这是正常的,可以通过手动输入代码的办法更改数据。下图为设置“name”为空。

三. 设置属性为唯一值

        设置禁止为唯一值有两个情况:第一种情况是增加一个新的列(属性),并把它设置为唯一值的状态。第二情况是将表中存在的某一列设置为唯一值。常见的有邮箱号不能重复使用,电话号,身份证号码登不能重复使用。

3.1 数据表添加唯一列

 ALTER TABLE student ADD test int(4) NOT NULL;

设置数据表 student 增加 非空列 test

测试是否添加成功

SHOW COLUMNS FROM student LIKE 'test';

3.2 尝试添加重复数据

第一步:给“张三”添加“123”

 第二步:给“李四”添加“123”。添加失败。

3.3 设置数据表某一列为唯一值

ALTER TABLE student CHANGE name name VARCHAR(20) UNIQUE;

将 student 表中的 name 设置为唯一值

命令原型:ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [约束];

四. 设置默认

ALTER TABLE student ADD post char(4) DEFAULT('学生');

设置默认值为学生

 刷新查看显示如下

五. 删除旧表创建新表

        DROP TABLE student;

        删除数据表

创建一个新的数据表

CREATE TABLE student(
id INT(4) PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(20) NOT NULL,
tel INT(11) UNIQUE,
sex char(1),
position VARCHAR(4) DEFAULT('学生'));

/* id主键自增,name 非空,tel 唯一,sex 正常字符型,position 职位默认学生 */

添加数据

INSERT INTO student
(name,tel,sex)
VALUES
('张三','1516666777','男'),
('张四','1516666778','男'),
('李三','1516666779','女'),
('李五','1516666780','男');

/* 插入四条数据。id是自增的,职位默认,所以不需要添加*/

查看数据 


        数据表中的某一列就是表的某一个属性。

        主键:数据库表中用于唯一标识每条记录的一列或一组列。主键在每个数据表中只能存在一个。    

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

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

相关文章

正则表达式-“三剑客”(grep、sed、awk)

1.3正则表达式 正则表达式描述了一种字符串匹配的模式,可以用来检查一个串是否含有某种子串,将匹配的子串替换或者从某个串中取出符号某个条件的子串等,在linux中代表自定义的模式模版,linux工具可以用正则表达式过滤文本。Linux…

vavr Java的函数式编程神器-Part1

微信公众号:阿俊的学习记录空间 小红书:ArnoZhang wordpress:arnozhang1994 博客园:arnozhang CSDN:ArnoZhang1994 1. 介绍 Vavr(前称 Javaslang)是一个为 Java 8 提供的函数式库,…

红外探测算法!!!

一、红外探测的基本原理 红外探测基于红外辐射与物体的热状态之间的关系。物体温度越高,辐射能量越大。红外探测器通过接收物体发出的红外辐射,将其转换为电信号,进而实现对目标的探测和识别。 二、红外探测算法的主要类型 背景差分法&…

[自然语言处理]RNN

1 传统RNN模型与LSTM import torch import torch.nn as nntorch.manual_seed(8)def dm01():参数1:输入向量的维数参数2:隐藏层神经元的个数参数3:隐藏层的层数:return:rnn nn.RNN(5, 6, 1)参数1:句子长度sequence_length参数2&am…

九芯电子NVH/NVF语音芯片OTA升级操作方法

OTA(Over-The-Air)升级是指通过无线网络远程对设备进行软件升级的过程。对于九芯电子NVH/NVF语音芯片,OTA升级可以通过WiFi模组实现,支持MQTT、HTTP等协议,方便快捷‌。 具体操作步骤如下: 1.进入九芯“智…

计算机毕业设计 基于Django的学生选课系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点…

处理Java内存溢出问题(java.lang.OutOfMemoryError):增加JVM堆内存与调优

处理Java内存溢出问题(java.lang.OutOfMemoryError):增加JVM堆内存与调优 在进行压力测试时,遇到java.lang.OutOfMemoryError: Java heap space错误或者nginx报错no live upstreams while connecting to upstream通常意味着应用的…

重头开始嵌入式第四十七天(硬件 ARM裸机开发 RS232 RS4885 IIC)

目录 一.什么是RS232? 1. 历史背景: 2. 电气特性: 3. 连接器类型: 4. 通信特点: 5. 应用场景: 二.什么是RS485? 1. 电气特性: 2. 通信模式: 3. 传输距离与速率&…

技术路线图用什么画?用这个在线工具轻松完成绘制!

在当今快速发展的技术世界中,技术路线图已成为企业和团队不可或缺的战略规划工具。它不仅能够清晰地展示技术发展方向,还能帮助团队成员、利益相关者和投资者更好地理解和参与技术战略的制定过程。但不可否认的是,创建一个有效的技术路线图并…

如何免费为域名申请一个企业邮箱

背景 做SEO的是有老是会有一些网站来做验证你的所有权,这个时候,如果你域名对应的企业邮箱就会很方便。zoho为了引导付费,有很多多余的步骤引导,反倒是让不付费的用户有些迷茫,所以会写这个教程,按照教程走…

虚幻引擎GAS入门学习笔记(二)

虚幻引擎GAS入门(二) 学习位置UE5.3 GAS入门教程重置版 小明 MVC框架与技能初始化 让一开始创建的蓝图的基础GameplayAbility蓝图继承我们写好的BaseGameplayAbility类 创建一个库函数,写一些常用的函数在里面第一个得到玩家与玩家控制器 获取角色面对目标的方向…

c++11~c++20 thread_local

线程局部存储是指对象内存在线程开始后分配,线程结束时回收且每个线程有该对象自己的实例,简单地说,线程局部存储的对象都是独立各个线程的。实际上这并不是一个新鲜个概念,虽然C一直没因在语言层面支持它,但是很早之前…

Coggle数据科学 | 全球AI攻防挑战赛:金融场景凭证篡改检测 baseline

本文来源公众号“Coggle数据科学”,仅用于学术分享,侵权删,干货满满。 原文链接:全球AI攻防挑战赛:金融场景凭证篡改检测 baseline 赛题名称:全球AI攻防挑战赛—赛道二(AI核身-金融场景凭证篡改…

集智书童 | FMRFT 融合Mamba和 DETR 用于查询时间序列交叉鱼跟踪 !

本文来源公众号“集智书童”,仅用于学术分享,侵权删,干货满满。 原文链接:FMRFT 融合Mamba和 DETR 用于查询时间序列交叉鱼跟踪 ! 鱼的生长、异常行为和疾病可以通过图像处理方法进行早期检测,这对工厂水产养殖具有重…

基于云效流水线Flow | 高效构建企业门户网站

基于云效流水线Flow | 高效构建企业门户网站 基于云效流水线Flow | 高效构建企业门户网站企业门户网站方案架构一键部署方案概览部署准备一键部署 部署服务端(云效流水线)添加流水线源Java构建上传主机部署 资源删除操作体验1) 在体验过程中是…

Redis 5 种基本数据类型的前两个详解

Redis 共有 5 种基本数据类型:String(字符串)、List(列表)、Set(集合)、Hash(散列)、Zset(有序集合)。 这 5 种数据类型是直接提供给用户使用的&…

qos在企业网中的设计与实现

1.拓扑 地址规划 业务地址规划 部门 地址空间 vlan 网关 市场部门 10.0.100.0/24 Vlan100 10.0.100.254/24 研发部门 10.0.101.0/24 Vlan101 10.0.101.254/24 财务部门 10.0.102.0/24 Vlan102 10.0.102.254/24 人力部门 10.0.103.0/24 Vlan103 10.0.103.25…

[nmap] 端口扫描工具的下载及详细安装使用过程(附有下载文件)

nmap网络连接端扫描软件,用于主机发现、端口扫描、版本侦测、操作系统侦测 下载链接在文末 下载压缩包后解压 !!安装路径不要有中文 解压得到文件 双击.exe文件 更改安装路径并点击安装 等待安装 安装完成 nmap-7.95-setup.zip 夸克网盘打开…

pip install kaggle-environments ISSUE:Failed to build vec-noise

ISSUE: error: Microsoft Visual C 14.0 or greater is required. Get it with “Microsoft C Build Tools”: https://visualstudio.microsoft.com/visual-cpp-build-tools/ [end of output]Failed to build vec-noiseC:\ProgramData\miniconda3\include\pyconfig.h(59): fat…

基于Springboot+Vue的家校互联系统(含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统中…