MySQL操作DDL

目录

1.概述

2.数据库的增删改查

3.表的增删改查

3.1.创建和查看表结构

3.2.修改表

3.3.查看所有的表

3.4.删除表

4.用户

5.DDL在实际应用场景中的作用

5.1.数据库设计

5.2.数据库维护

​​​​​​​5.3.数据库迁移或重置

​​​​​​​5.4.优化性能

​​​​​​​5.5.小结


1.概述

        啥是DDL?我们数据库的课程里应该学过。DDL就是Data Definition Language的首字母,即数据定义语言。是一类用于定义和修改数据库结构的语言。使用户能够创建、修改、删除数据库中的各种对象,如表、视图、索引、触发器等。DDL作为SQL(Structured Query Language,结构化查询语言)的一个重要组成部分,其指令主要涉及数据库模式的创建和维护。主要包括create、alter、drop等指令。

2.数据库的增删改查

  • 创建数据库:create database 数据库名;
  • 创建数据库并指定编码:utf8,设置好后,数据库中就可以存储中⽂数据。create database 数据库名 charset utf8;
  • 使⽤数据库:use 数据库名;
  • 查看所有数据库:show databases; #查看当前所有数据库。
  • 单独常看当前数据库:select database(); #查看当前使⽤的是哪⼀个数据库。
  • 修改数据库:数据库的名称⼀旦创建好之后就⽆法修改。
  • 删除数据库:drop database 数据库名;

3.表的增删改查

3.1.创建和查看表结构

create table 表名(

字段名1 类型(宽度) 约束条件,

字段名2 类型(宽度) 约束条件,

字段名3 类型(宽度) 约束条件,

);

注意:

  • 字段名不能重复
  • 字段名和类型是必选
  • 宽度和约束条件可选

查看表结构:desc 表名;

例如:

create table student(

name char(10),

age int,

score float(5,2),

startTime time,

lesson

set('English','Math','Chinese'),

sex enum('male','female')

);

> OK

> 时间: 0.008s

desc student;

约束:

        为了防⽌不符合规范的数据进⼊数据库,在⽤户对数据进⾏插⼊、修改、删除等操作时,数据库需要按照⼀定的约束条件对数据进⾏监测,使不符合规范的数据不能进⼊数据库,以确保数据库中存储的数据正确性和有效型。

约束条件主要分为以下⼏种: 

  • NOT NULL:⾮空约束,指定某列不能为空
  • DEFAULT:默认值
  • UNIQUE:唯⼀约束,指定某列或者⼏列组合不能重复
  • PRIMARY KEY:主键,指定该列的值可以唯⼀地标识该列记录
  • FOREIGN KEY:外键,指定该⾏记录从属于主表中的⼀条记录,主要⽤于参照完整性

primary key:

主键,为了保证表中的每⼀条数据的该字段都是表格中的唯⼀值。是⽤来独⼀⽆⼆地确认⼀个表格中的每⼀⾏数据。

create table tp (

id int PRIMARY KEY , #主键约束

name varchar(20),

salary float(6,2)

)

auto_increment:

⾃增字段,对于主键id⽽⾔,往往我们可以设置为⾃增字段,不⽤⼿动填写。

create table ta(

id int PRIMARY KEY auto_increment, #主键约

name varchar(50)

)

not null:

非空,当设置⼀个字段时,不允许它为空,可以使⽤此约束条。

create table tn (

id int PRIMARY KEY auto_increment, #主键约束

name varchar(50) not null #name字段的值不可以为空

)

default:

默认值,例如:对于性别⼀列,如果⼤部分都是男性,可以设置成默认值,不填则取默认值,填写了则覆盖默认值。

create table td (

id int PRIMARY KEY auto_increment, #主键约束

name varchar(50),

sex char(20) DEFAULT('male')

)

unique:

唯⼀值,当有⼀列字段你不想让它有重复值时,可以设置为唯⼀。

create table tu (

id int PRIMARY KEY auto_increment, #主键约束

name varchar(50) unique, #唯⼀约束

)

联合唯⼀:

只有当你设置的这些字段同时重复时才会报错

create table tu1 (

id int PRIMARY KEY auto_increment, #主键约束

name varchar(50),

dep char(10),

UNIQUE(name,dep) #联合唯⼀约束

)

foreign key:

外键,假设我们要描述所有公司的员⼯,需要描述的属性有:姓名,年龄,性别,部⻔,部⻔描述。

假设公司有3个部⻔,但是有一千万的员⼯,那意味着部⻔和部⻔描述这两个字段需要重复存储,部⻔名字和部⻔描述内容越⻓,越浪费内存,该如何处理?

解决办法:我们可以定义⼀个部⻔表然后让员⼯信息表关联该表,如何关联,即foreign key。

创建两张表:

被关联表:dep

create table dep(

id int primary key auto_increment,

dep_name varchar(20),

dep_desc varchar(200));

关联表:emp

create table emp(

id int primary key auto_increment,

name varchar(20),

age int,

gender enum('male','female'),

dep_id int not null,

foreign key(dep_id) references

dep(id));

级联删除、更新:

两张表建⽴关联之后,如果部⻔表某个部⻔被砍掉了,那对应的⼈员表中的那些部⻔的⼈员相应的该如何处理呢?可以保存,也可以随之⼀起删除。如果要保证两表⼀致,则需要在设置外键时添加on delete cascade,如果部⻔id更新了,要⼀起更新的话,则添加on update cascade。

被关联表:dep

create table dep001(

id int primary key auto_increment,

dep_name varchar(20),

dep_desc varchar(200));

关联表:emp

create table emp001(

id int primary key auto_increment,

name varchar(20),

age int,

gender enum('male','female'),

dep_id int not null,

foreign key(dep_id) references

dep001(id) on delete cascade on update

cascade

);

​​​​​​​3.2.修改表

修改表名:

alter table 旧表名 rename 新表名

修改表字段的数据类型:

alter table 表名 modify 字段 新数据类型

修改表字段名:

alter table 表名 change 旧字段名 新字段名 新数据类型

新增字段:

alter table 表名 add 新增字段名 数据类型 约束条件#约束条件可选

删除字段:

alter table 表名 drop 字段名

​​​​​​​3.3.查看所有的表

show tables;

​​​​​​​3.4.删除表

drop table 表名;

使用`DROP`时需谨慎,它将从数据库中永久删除所选对象。

truncate table 表名;

`TRUNCATE`指令用于删除表中的所有行,但不删除表本身。与`DROP TABLE`相比,它删除数据的速度更快且效率更高。

4.用户

为了呼应后续继续写的内容,本节插入一段DCL相关内容。

创建用户 xyz , 只能够在当前主机localhost访问, 密码123456;

create user 'xyz'@'localhost' identified by '123456';

创建用户 abcd, 可以在任意主机访问该数据库, 密码123456 ;

create user 'abcd'@'%' identified by '123456';

修改用户 abcd 的访问密码为 5678;

alter user 'abcd'@'%' identified with mysql_native_password by '5678';

删除xyz@localhost用户

drop user 'xyz'@'localhost';

查询权限

show grants for 'abcd'@'%';

授予权限

grant all on xyz.* to 'abcd'@'%';

撤销权限

revoke all on xyz.* from 'abcd'@'%';

5.DDL在实际应用场景中的作用

5.1.数据库设计

        在数据库设计阶段,通过使用DDL的`CREATE`指令创建数据库以及数据库内所需的表和其他对象,是数据库建设的初期步骤。

​​​​​​​5.2.数据库维护

        数据需求随时可能改变,使用`ALTER`指令可以针对现有数据库结构进行调整,如添加新列来存储额外信息,或者修改现有列的数据类型以适应数据格式的变化。

​​​​​​​5.3.数据库迁移或重置

        在数据库迁移或需要重置数据时,可能会使用到`DROP`指令删除旧的数据库对象或`TRUNCATE`指令清空表中的数据,以便重新开始或导入新的数据集。

​​​​​​​5.4.优化性能

        当数据库中的某些表不再需要时,使用`DROP`指令删除这些表可以帮助减少数据库的大小,从而提高整体性能。同样,使用`TRUNCATE`快速清空表中数据也是常见的优化手段之一。

​​​​​​​5.5.小结

        数据库DDL是数据库管理和维护的一项重要工具。通过熟练使用`CREATE`、`ALTER`、`DROP`和`TRUNCATE`等指令,DBA可以有效地控制和管理数据库的结构。每一条DDL指令针对的是数据库结构层面的操作,对于数据库设计、维护和优化等多个环节都有着至关重要的作用。尽管DDL操作通常由具有数据库设计经验的技术人员执行,了解这些基础的DDL操作对于任何希望深入理解数据库运作的人来说都是十分有益的。

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

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

相关文章

cesium 添加动态波纹效果 圆形扩散效果 波纹材质

一、扩展材质 /*** 水波纹扩散材质* param {*} options* param {String} options.color 颜色* param {Number} options.duration 持续时间 毫秒* param {Number} options.count 波浪数量* param {Number} options.gradient 渐变曲率*/function CircleWaveMaterialProperty(opt…

网络学习学习笔记

NETEBASE学习笔记 一.VRP系统1.四种视图模式2.基础命令 二.TCP/IP1.五层模型 一.VRP系统 1.四种视图模式 (1)< Huawei > 用户视图 【查看运行状态】 (2)[Huawei] 系统视图 【配置设备的系统参数】 system-view /sys 进入系统视图 CtrlZ/return 直接返回用户视图 (3)[Hua…

centos7升级openssl1.1.1w版本

下载 https://www.openssl.org/source/old/1.1.1/index.html 安装依赖 yum install gcc libffi-devel zlib* openssl-devel libffi-devel zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make解压、编译、安装 tar -zxvf o…

ADS1299模拟前端(AFE)代替料LHE7909

今天我和大家分享一颗国产可以代替ADS1299的料——LHE7909&#xff0c;这是一颗由领慧立芯设计生产的一款具备颅外脑电图(EEG)和心电图(ECG)应用所需的全部常用功能的模拟前端芯片&#xff0c;并且凭借其高集成度和出色的性能&#xff0c;能够创建多种可扩展的医疗仪器系统&…

Druid面试题及参考答案

1. Druid是什么?它的主要特点有哪些? Druid是一个高效的数据查询系统,主要解决的是对于大量的基于时序的数据进行聚合查询。它的主要特点包括: 实时数据摄入:Druid能够实时地摄入数据,对于流式数据的处理非常高效。高性能查询:Druid提供了快速的数据查询能力,即使是对…

【金句推荐】适合写进摘抄本的优美句子

1.人间骄阳刚好&#xff0c;风过林梢&#xff0c;彼时他们正当年少。 2.这路遥马急的人间渐行、渐远、渐无声&#xff0c;看淡若清风的现世且听、且吟、且从容。 3.一个能够升起月亮的身体&#xff0c;必然驮住了无数次日落。 4.并不可否认&#xff0c;生活磨掉了我们一部分…

数学建模-------MATLAB分支循环断点调试

1.if语句 &#xff08;1&#xff09;分段函数的引入&#xff08;这里的数据表示的是分数的不同区间对应的等级&#xff09; (1)这个就是一个十分简单的if语句&#xff0c;无论是if还是elseif后面都是不能添加任何分号的&#xff0c;这个例子就是一个分段的函数&#xff0c;在不…

mac/win使用pyinstaller打包app/exe文件,活着执行脚本,双击运行

&#x1f338; 踩坑记录 python环境最好使用虚拟环境&#xff0c;推荐使用conda管理&#xff0c;并且若本地有python环境&#xff0c;不要使用和 本地环境版本 相同的虚拟环境 这里踩坑较多&#xff0c;已经记不清楚注意点 虚拟环境python版本不要和本地环境一样 mac/win只能…

nodejs安装及环境配置

Node.js安装和环境配置在不同操作系统&#xff08;如Windows、macOS、Linux&#xff09;上会有所不同。以下是一些基本的步骤和指南来帮助你在这些常见的操作系统上安装Node.js及进行环境配置。 ### Windows #### 安装Node.js 1. **下载安装包**&#xff1a;访问Node.js官方…

清理垃圾软件哪个好?电脑清理优化4种方法

在数字时代&#xff0c;我们的电脑经常会被各种软件、程序和文件所占据&#xff0c;其中不乏一些无用甚至有害的垃圾软件。这些软件不仅占用了大量的存储空间&#xff0c;还可能拖慢电脑的运行速度&#xff0c;甚至威胁到我们的信息安全。因此&#xff0c;定期清理和优化电脑变…

紧急备考全攻略,如何短期通过PMP考试?

今年身边有很多同事朋友都要考PMP&#xff0c;而我属于这些人里”第一个吃螃蟹“的人&#xff0c;一次拿下5A&#xff0c;下面分享一下我自己备考PMP的经验。 我是根据自己的学习计划复习的&#xff0c;不能说这些方法适合所有人&#xff0c;但对备考的伙伴们来说&#xff0c;…

【考研复试上机】C++STL

文章目录 vector初始化及赋值方式vector容器内元素的访问常用函数 setset容器内元素的访问&#xff1a;set常用函数&#xff1a;multisetunordered_set stringstring常用函数&#xff1a; mapmap容器内元素的访问&#xff1a;map常用函数&#xff1a;multimapunordered_map que…

颜色识别

颜色识别 计算机视觉中的颜色识别是指计算机系统能够自动识别图像或视频中的不同颜色&#xff0c;以便进行分析、分类、跟踪和其他视觉任务。 颜色是物体的一个重要属性&#xff0c;它提供了有关对象的重要信息。 颜色识别在各种应用中都有重要作用&#xff0c;包括工业自动…

分布式文件系统

引言&#xff1a; GFS是一个可扩展的分布式文件系统&#xff0c;用于大型的、分布式的、对大量数据进行访问的应用。它运行于廉价的普通硬件上&#xff0c;并提供容错功能。它可以给大量的用户提供总体性能较高的服务。 一、 GlusterFS 概述 1.1 GlusterFS简介 GlusterFS 是…

跳动的♥心

代码&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><style…

git实现代码版本控制

一、在github新建一个仓库 二、在本地执行以下代码 git init git add . git commit -m "first commit" git branch -M main git remote add origin gitgithub.com:thekingofjumpshoot/blog.git git push -u origin main 代码解析 然后就上传到github上了 三、第二…

Java 8 中Stream流的基本概念和用法介绍

1. 理解Java 8中Stream流的概念 Java 8中引入的Stream流是对集合对象进行各种操作的高级抽象&#xff0c;可以让开发者更加便捷、高效地处理数据。在本章节中&#xff0c;我们将深入探讨Java 8中Stream流的基本概念&#xff0c;包括Stream流的定义、与集合的关系以及使用Strea…

qt实现实时抓取串口数据,并对数据做解密处理

效果&#xff1a; 1.实时抓取串口数据&#xff0c;并对串口数据做解密&#xff0c;解密后显示在QTextEdit上。 2.对显示的内容做特殊关键字标记处理&#xff0c;比如对出现的Error关键字标红 高亮另一个版本 3.对显示的明文进行查询&#xff0c;类似编辑文件中的CtrlF 4.对串口…

Mac环境简化RSA密钥生成命令

文章目录 正常RSA密钥对生成操作命令 openssl genrsa -out rsa_private_key.pem 2048 openssl rsa -pubout -in rsa_private_key.pem -out rsa_public_key.pem通过添加环境变量来简化RSA密钥对生成操作 设置环境变量.zshrc或.bash_profile # 使用zsh终端 vim ~/.zshrc将下面sh…

如何通过代码混淆绕过苹果机审,解决APP被拒问题

目录 iOS代码混淆 功能分析 实现流程 类名修改 方法名修改 生成垃圾代码 替换png等静态资源MD5 info.plist文件添加垃圾字段 功能分析 实现流程 类名修改 方法名修改 生成垃圾代码 替换png等静态资源MD5 info.plist文件添加垃圾字段 混淆前后对比 iOS代码混淆 …