MySQL操作DDL

news2024/11/28 14:55:00

目录

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.coloradmin.cn/o/1576893.html

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

相关文章

IoTeX的旅程并非孤军奋战

自2017年起,IoTeX便作为一个雄心勃勃的开源项目,踏上了一条为机器打造开放经济的道路。这个宏伟的目标背后,是一个去中心化的平台愿景,一个能够让人类和机器在有保障的信任、自由意志及精心设计的经济激励下相互协作的开放生态系统…

高项-案例分析练习(成本管理)

题目来源:信管网 案例一 某企业承接了某政府部门的系统集成项目,项目投标费用为5万元,预计每个子项目开发完成后的维护成本为50万元,项目初步的WBS分解结构如图所示。 题目一 【问题1】(2分) 假如估算出子…

BM96 主持人调度(二)(贪心算法)

一开始写的时候忘了给start、end数组赋值了 import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** 计算成功举办活动需要多少名主持人* param n int整型 有n个活动* param start…

Walmart.com DSV XML对接需求

此前的文章Walmart.com DSV EDI对接需求中,为大家介绍了如果选择传输EDI文件需要做的准备与需求。本文将为大家介绍Walmart.com 与DSV(Drop Ship Vender)之间传输XML文件的需求。与EDI相比,XML文件的处理难度相对低一些。无论企业…

LiveGBS流媒体平台GB/T28181常见问题-系统服务日志如何配置日志个数日志路径日志时长web操作日志操如何配置保留天数及过滤

LiveGBS系统服务日志如何配置日志个数日志路径日志时长web操作日志操如何配置保留天数及过滤 1、系统服务日志1.1、日志目录1.2、配置日志文件个数及记录时间1.3、配置日志文件路径 2、Web 操作日志2.1、配置保留天数2.2、配置不记录操作日志2.1.1、不记录所有2.1.2、不记录指定…

Python爬虫学习(三):parsel解析html

parse中可以使用css及xpath对html和xml进行解析,其中主要用到的方法如上图所示,并支持使用 XPath 和 CSS Selector 对内容进行提取和修改,同时它还融合了正则表达式提取的功能。方法使用代码示例如下,关于xpath相关方法的使用可以…

生产管理系统软件有哪些?盘点2024年五大好用的生产管理系统软件

生产管理系统软件有哪些?盘点2024年五大好用的生产管理系统软件! 一、为什么要使用生产管理系统? 为什么很多中小企业微制造的企业抱怨道:“订单越来越多,但利润越来越薄”?主要是因为传统中小微型制造企…

2024年最新渗透测试工具,看完赶紧存了!(工具包限时分享)

前言: 为了保护网络及国家安全,国家增强了对网络安全人才培养与建设的投入力度。网络安全相关职位的薪资待遇颇为丰厚,相关资格证书的补贴也相当可观,吸引了大批网安爱好者前来学习。但网络安全领域并不缺乏从业者,而…

基于LNMP环境上线QQ农场

目录 一.介绍 二. 环境准备 三.安装Mysql数据库 四.安装PHP 五.安装Nginx 六.测试Nginx服务于PHP服务是否能关联 七.项目上线 QQ农场源码:做本项目默认操作者有一定的基础知识与理解能力 链接:https://pan.baidu.com/s/1HF8GZ-yvNh7RbJ61nXOW-g?…

3.网络编程-TCP

目录 TCP 建立连接的过程是怎样的 TCP为什么是三次握手 TCP 断开连接的过程是怎样的 TCP挥手为什么需要四次 为什么TIME_WAIT等待的时间是2MSL TCP详解之滑动窗口 TCP 半连接队列和全连接队列是什么 TCP粘包,拆包是怎么发生的,如何解决 TCP是如何…

使用docker-compose创建多项目容器运行

使用docker-compose创建多项目容器运行 按招网友提供方法创建 docker-compose.yml内容(这里改了桥接模式,并且注释放开)version: "3" services:docker_python:image: python:2.7.18container_name: py_appworking_dir: "/root"restart: alwaysvolumes:-…

分享几个免费的SSL证书/https证书

我们要明确什么是SSL证书。SSL,全称为Secure Sockets Layer,即安全套接层,是一种用于保障网络数据传输安全的技术。通过使用SSL证书,可以确保用户在访问网站时的数据传输过程中不被第三方窃取或篡改,从而保障用户的隐私…

有些人有些事,看开就好

前一段时间收到客户询盘部署一个系统500行不?一次性搭建60套,按照我的报价300*60?这么大的馅饼么?这个月营收要爆棚了。用小米的Slogon来讲:永远相信美好的事情即将发生。本以为是个意外惊喜,没想到社会果然…

nssm 工具把asp.net core mvc变成 windows服务,使用nginx反向代理访问

nssm工具的作用&#xff1a;把项目部署成Windows服务&#xff0c;可以在系统后台运行 1.创建一个asp.net core mvc的项目weblication1 asp.net core mvc项目要成为windows服务需要安装下面的nuget包 <ItemGroup><PackageReference Include"Microsoft.Extension…

小红书商业IP变现策略与实操经验分享

一、个人介绍与背景 1. 创业者背景 作为连续创业者&#xff0c;我创立了树叶有光品牌&#xff0c;并在多个领域有所涉猎&#xff0c;如人生陪跑师、财富卡点爆破师等。这些多重身份让我在创业过程中积累了丰富的经验和独特的视角。 二、小红书账号运营经验 1. 运营成果 经…

基于ssm办公用品管理系统开发与设计论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本办公用品管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据信息…

【边缘智能】00_边缘计算发展背景

本系列是个人学习《边缘就算基础知识入门》的笔记&#xff0c;仅为个人学习记录&#xff0c;欢迎交流&#xff0c;感谢批评指正 移动物联设备产生海量数据&#xff0c;数据密集型移动智能应用&#xff0c;计算密集、动态性高&#xff0c;实时性强 传统云计算架构 基于广域互联…

JavaScript - 请你为数组自定义一个方法myFind,使其实现find方法的功能

难度级别:中级及以上 提问概率:50% 我们知道数组的find方法是ES6之后出现的,它强调找到第一个符合条件的元素后即跳出循环,不再继续执行,那么如果不用ES6的知识,为数组添加一个自定义方法实现find方法的功能,首先要想到在数组的原型pro…

✌2024/4/3—力扣—字符串转换整数

代码实现&#xff1a; int myAtoi(char *str) {long ret 0;int flag 1; // 默认正数// 去除空格及判断符号位while (*str ) {str;}if (*str -) {flag -1;str;} else if (*str ) {str;}// 排除非数字的情况if (*str < 0 || *str > 9) {return 0;}while (*str > …

文章解读与仿真程序复现思路——电力系统自动化EI\CSCD\北大核心《考虑灵活爬坡产品的虚拟电厂两阶段分布鲁棒优化运营策略》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…