数据库设计-DDL

D D L \huge{DDL} DDL
DDL:数据库定义语言,用来定义数据对象(数据库、表)

简单操作

首先在cmd中进行操作,登录数据库

show databases;		-- 以列表的形式显示所有的数据库

在这里插入图片描述

create database [if not exists] 数据库名称		-- 创建数据库

在这里插入图片描述

use 数据库		-- 切换使用的数据库 

在这里插入图片描述

select database()				-- 显示当前正在使用的数据库是哪一个数据库

在这里插入图片描述

drop database [if exists] 数据库名称		-- 删除数据库

在这里插入图片描述
db01已经被删除。

IDEA中集成MySQL

直接在cmd中使用MySQL没有语法补全非常的难受,可以在IDEA中集成MySQL,就可以将大批量的SQL语言转换为图形操作。(❗❗但并不是说SQL语言就不重要了!!

①. 启动IDEA

②. 集成MySQL

在IDEA边栏找到DataBase,导入MySQL数据库
在这里插入图片描述
进入这个界面:
在这里插入图片描述
主机端口号什么的不用动,只要填写User与Password即可(就是刚才在cmd中注册),然后点击下面的Test Connection来测试是否连接成功,如果没有相关的依赖jar包,则需要在此界面下载。
在这里插入图片描述
连接通过,确定即可。

③. IDEA集成MySQL界面介绍

在这里插入图片描述
勾选了All schemas可以显示所有的数据库,包括MySQL本身的系统数据库。
❗❗注:schemas == database,两者指的是一个东西
在这里插入图片描述
左上角的+号可以呼出控制台Console
在这里插入图片描述
数据库中的层级结构
IDEA中MySQL集成完毕后,就可以正式开始DDL的学习了。

DDL

⭐⭐⭐⭐⭐建表

create table 表名字(字段1 字段类型 [约束][comment 字段1注释],.....字段n 字段类型 [约束][comment 字段n注释]
)[comment 表注释];

约束用来限制表中的字段数据,保证表中的数据的正确性有效性等。
常见约束:
在这里插入图片描述
示例:

create table tb_user(id int comment 'ID, 唯一标识',username varchar(20) comment '用户名',name varchar(10) comment '姓名',age int comment '年龄',gender char(1) comment '性别'
) comment '用户表';

❗DDL中的字符串类型可不是String,是varchar(),后面是字符串的长度。
带有约束的建表语句:

-- 创建: 基本语法 (约束)
create table tb_user(id int primary key auto_increment comment 'ID, 唯一标识',username varchar(20) not null unique comment '用户名',name varchar(10) not null comment '姓名',age int comment '年龄',gender char(1) default '男' comment '性别'
) comment '用户表';

IDEA中的图形化建表
再数据库上右键,找到如下的栏目:
在这里插入图片描述
建表新旧UI都可以,但是个人感觉旧UI建表更方便。
在这里插入图片描述
上面改表名字,下面+可以添加数据列。
在这里插入图片描述
从左到右上面三栏依次为名字类型和默认值。最右侧的气泡部分则是comment解释
在这里插入图片描述
可以为新建的数据栏写一点注解什么的。
在这里插入图片描述
下面三个约束依次为 非空,自增,值唯一和主键,需要什么就勾选什么的。

建表语句示例:

create table tb_emp(id int primary key auto_increment comment '主键ID',username    varchar(20)                  not null comment '用户名',password    varchar(32) default '123456' null comment '密码',name        varchar(10)                  not null comment '姓名',gender      tinyint unsigned             not null comment '性别, 1 男, 2 女',image       varchar(300)                 null comment '图像url',job         tinyint unsigned             null comment '职位, 1 班主任 , 2 讲师 , 3 学工主管, 4 教研主管',entrydate   date                         null comment '入职日期',create_time datetime                     not null comment '创建时间',update_time datetime                     not null comment '修改时间',constraint tb_emp_username_uindex unique (username)
) comment '员工表';

❗特别注意的是,无论什么表都有两个数据列是通用的,就是create_time和update_time,表创建时间和表的修改时间。

查询表

-- 查询数据当前的所有表
show tables;
--查询表的结构
desc 表名;
-- 查询建表语句
show create table 表名;

表修改

在这里插入图片描述
示例:

-- DDL: 修改表结构
-- 修改: 为表 tb_emp 添加字段 qq varchar(11)
alter table tb_emp add qq varchar(11) comment 'QQ';-- 修改: 修改 tb_emp 字段类型 qq varchar(13)
alter table tb_emp modify qq_num varchar(13) comment 'QQ';-- 修改: 修改 tb_emp 字段名 qq 为 qq_num varchar(13)
alter table tb_emp change qq qq_num varchar(13) comment 'QQ';-- 修改: 删除 tb_emp 的 qq_num 字段
alter table tb_emp drop column qq_num;-- 修改: 将tb_emp 表名修改为 emp
rename table tb_emp to emp;

此操作同样可以再IDEA中图形化
在这里插入图片描述
在这里插入图片描述

表删除

删除表:

drop table [if exists] 表名;

表被删除了内部的内容也就被删除了。
❗❗❗谨慎操作!!!
图形化操作:
在这里插入图片描述

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

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

相关文章

[C#]使用DlibDotNet人脸检测人脸68特征点识别人脸5特征点识别人脸对齐人脸比对FaceMesh

【官方框架地址】 https://github.com/takuya-takeuchi/DlibDotNet 【算法介绍】 DlibDotNet是一个开源的.NET库,用于实现机器学习和计算机视觉应用。它基于C库dlib,通过C/CLI封装了dlib的所有功能,为.NET开发者提供了简单易用的API。以下是…

Nacos 持久化及集群的搭建【微服务】

文章目录 一、统一配置管理二、微服务配置拉取三、配置热更新四、多环境共享配置五、Nacos 集群搭建1. 集群结构2. 初始化数据库3. 搭建集群 六、Nginx 反向代理七、启动项目测试 一、统一配置管理 案例练习的时候我们只有两个微服务,管理起来非常简单,但…

el-upload上传文件

需求:选中或拖拽文件后,使用http-request属性实现自动上传,并根据后端传回来的结果显示错误和控制fileList的显示,如果后端返回成功,则文件显示在文件列表处,如果后端返回失败,则文件列表不显示…

Qt/QML编程学习之心得:Timer的使用(22)

Qt中timer计时器如何使用? Timer的创建: void InitTimer(){myTimer = new QTimer(q);myTimer->setInterval(100); // 100msmyTimer->setSingleShot(true); //只运行一次的计时器QObject::connect(myTimer,SIGNAL(timeout()),q,SLOT(onTimeOut()));myTimer->start(…

Oracle分区表

文章目录 A. varchar2类型时间字段(20240102)分区实战1. 表要不要分区2. 将已经存在的表改造为分区表(时间字段,varchar2类型)3. 增加分区3.1 增加分区3.2 置换分区,不会复制索引,不要用这种语法建表,这是专门为置换分区用的3.3 分…

SonarQube 漏洞扫描

SonarQube 漏洞扫描 一、部署服务 1.1 docker方式部署 #安装docker curl -L download.beyourself.org.cn/shell-project/os/get-docker-latest.sh | sh yum install -y docker-compose #进去输入:set paste可以保证不穿行 [rootlocalhost sonar]# vim docker-compose.yml v…

java基于SSM的游戏商城的设计与实现论文

基于SSM的游戏商城的设计与实现 摘 要 当下,正处于信息化的时代,许多行业顺应时代的变化,结合使用计算机技术向数字化、信息化建设迈进。以前相关行业对于游戏信息的管理和控制,采用人工登记的方式保存相关数据,这种以…

【C++】内存对齐

本篇文章介绍C中的内存对齐,后续介绍C的union和C的variant的时候,需要用到这部分的知识。 占用内存 先回忆下C各个数据类型占用的内存大小: int:所占内存大小:4byte 32bit;char:所占内存大小…

x-cmd-mod | zuz - 压缩或解压文件

目录 简介首次用户子命令x zuz zx zuz uzx zuz uzrx zuz ls 相关链接 简介 zuz 为 x-cmd 中的必用模块之一,提供压缩与解压文件的功能。 x z 就是调用 x zuz z,可将目标文件压缩根据后缀名成指定格式,x uz 则可以解压任何格式的压缩包 首次…

四个模型建模及数据分析整理(基于Titanic数据集)

目录 介绍: 二、数据 2.1引用数据 2.2检查缺失数据 2.2.1手动检查缺失数据 2.2.2查看某一个特征值为空数据 2.3补充缺失数据 2.3.1盒图 2.3.2手动用均值填补缺失数据 2.3.3手动用类别填补缺失数据 三、数据分析 3.1男女生存比例 3.2男女生存数 3.3船舱级…

ROS学习笔记(11)进一步深入了解ROS第五步

0.前提 我在学习宾夕的ROS公开课的时候发现,外国的对计算机的教育和国内的是完全不一样的,当你接触了外国的课程后回头看自己学的会发现好像自己啥也没学。我这里可以放出来给大家看一下。 1.Python and C 2.Python PDB Tutorial:Python Deb…

PyTorch|构建自己的卷积神经网络

如何搭建网络,这在深度学习中非常重要。简单来讲,我们是要实现一个类,这个类中有属性和方法,能够进行计算。 一般来讲,使用PyTorch创建神经网络需要三步: 继承基类:nn.Module 定义层属性 实现…

动态规划(不同路径1,不同路径2,整数拆分)

62.不同路径 力扣题目链接(opens new window) 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。…

手机上连网络转接app,电脑连接手机,共用网络转接app的办法

方法一,(不推荐) 因为太简单了所以写一下 电脑安装MuMu模拟器,之后安装网络转接app,这个模拟器设置了从电脑上安装app和,安卓与电脑同步文件夹功能,实现文件共享。所以直接用就可以了。 方法二…

启动 Mac 时显示闪烁的问号

启动 Mac 时显示闪烁的问号 如果启动时在 Mac 屏幕上看到闪烁的问号,这意味着你的 Mac 无法找到自身的系统软件。 如果 Mac 启动时出现闪烁的问号且无法继续启动,请尝试以下步骤。 1.通过按住其电源按钮几秒钟来关闭 Mac。 2.按一下电源按钮&#xf…

你珍藏的那个表情包女孩,现在滤镜碎了一地。

♥ 为方便您进行讨论和分享,同时也为能带给您不一样的参与感。请您在阅读本文之前,点击一下“关注”,非常感谢您的支持! 文|猴哥聊娱乐 编辑|侯欢庭 七年前,一个年仅三岁的小女孩以其无邪的表情包风靡网络&#xff0…

FindMy技术用于键盘

键盘是我们生活中不可或缺的输入工具,是人与计算机之间沟通的桥梁,无论是编写文档、浏览网页、玩游戏、或是进行复杂的数据分析,键盘都在其中发挥着关键的作用。此外,键盘还是各种软件的快捷键操作的关键。通过熟练地运用快捷键&a…

大学物理-实验篇——测量误差与数据处理(测量分类、误差、有效数字、逐差法)

目录 测量分类 测量次数角度 测量条件角度 误差 误差分类 系统误差 随机误差 异常值 误差描述 精密度(Precision) 正确度(Trueness) 准确度/精确度(Accuracy) 随机误差的处理 直接测量 算术…

Opencv(C++)学习之cv::calcHist 任意bin数量进行直方图计算

**背景:**当前网上常见的直方图使用方法都是默认使用256的范围,而对于使用特定范围的直方图方法讲的不够清楚。仔细研究后总结如下: 1、常见使用方法,直接对灰度图按256个Bin进行计算。 Mat mHistUn; int channels[1] { 0 }; {…

rollup 原理解析

✨专栏介绍 Rollup专栏是一个专门介绍Rollup打包工具的系列文章。Rollup是一个现代化的JavaScript模块打包工具,它可以将多个模块打包成一个或多个文件,以提高应用程序的性能和加载速度。 在Rollup专栏中,您将学习到如何安装和配置Rollup&a…