02--数据定义语言DDL

1、数据定义语言DDL

1.1 操作数据库-DDL

创建数据库

create database 数据库名称;

创建数据库,并指定字符集

create database 数据库名称 character set 字符集名;

查询所有数据库的名称

show databases;

查询某个数据库的字符集:查询某个数据库的创建语句及字符集

show create database 数据库名称;

修改数据库的字符集

alter database 数据库名称 character set 字符集名称;

删除数据库

drop database 数据库名称;

使用数据库

use 数据库名称;

查询当前正在使用的数据库名称

select database();

查看数据库版本号

select version();

1.2 操作表-DDL

1.2.1 什么是表

表:table

表:table是数据库的基本组成单元,所有的数据都以表格的形式组织,目的是可读性强。

一个表包括行和列:

行:被称为数据/记录(data)

列:被称为字段(column)

每一个字段应该包括哪些属性?

字段名、数据类型、相关的约束。

1.2.1 数据类型

数据类型

说明

int

整数类型,例如 : age

double

小数类型,例如 : score double(5,2) 111.11

date

日期,只包含年月日,yyyy-MM-dd

datetime

日期,包含年月日时分秒 yyyy-MM-dd HH:mm:ss

timestamp

时间戳类型,包含年月日时分秒 yyyy-MM-dd HH:mm:ss 如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值

varchar

可变字符 name varchar(20)

char

不可变字符 name varchar(20)

VARCHAR、CHAR

varchar:表示的长度可变的字符串。最大长度不能超过定义字段的时候长度。

char:长度固定。

name varchar(20):name 存贮数据的长度是20以内的,lisi 表示4个长度 ,zhangsan:8个长度 江一燕:3个长度

name char(20):lisi 当前的长度4,剩下的是空格 。

问题:char 的性能好。 varchar可以节省空间。通常时候,我们使用varchar。

使用char的情况。当某个字段的长度固定的时候,可以采用char。例如身份证号、性别、手机号。

1.2.2 创建表

语法:

create table 表名(
  列名(字段名) 数据类型,
  列名(字段名) 数据类型,
  列名(字段名) 数据类型
  ...
);

示例:

create table student(
	id int,
  name varchar(20),
  sex char(1),
  birth date,
  money double
);

注意事项:最后一列,不需要加逗号(,)

查看建表语句:

show create table student;

1.2.3 查询表

查询某个数据库中所有的表名称

show tables;

查询表结构

desc 表名;

1.2.4 修改表

添加一列

语法:
    alter table 表名  add 列名 数据类型 约束;
实例:
    alter table student add classes varchar(10);

修改列类型

语法:
    alter table 表名 modify 列名 新类型;
实例:
    alter table student modify classes varchar(20);

修改列名和类型

语法:
    alter table 表名 change 旧列名 新列名 新类型;
实例:
    alter table student change classes class varchar(10);

删除指定列

语法:
    alter table 表名 drop 列名;
实例:
    alter table student drop class;

修改表字符集

语法:
    alter table 表名 charset 字符集;
实例:
    alter table student charset gbk;

修改表名

语法:
    rename table 旧表名 to 新表名;
实例:
    rename table student to stu;

1.2.5 删除表

直接删除表
    语法:
        drop table 表名;
    实例:
        drop table student1;

如果表存在就删除,不会报错

drop table if exists stu;  

1.3 约束

1.3.1 约束概述

约束:规定,限制。限制表中的内容。需要满足一定的规则。数据库中的约束:限制列的内容。

意义:保证数据的有效性和完整性。可以确保数据库满足业务规则。

1.3.2 约束类型

约束

说明

primary key

主键约束:非空且唯一

unique

唯一约束 : 某一列的值不能重复,但可以为空

not null

非空约束 : 某一列的值不能为空

foreign key

外键约束

缺省

默认值

auto_increment

自增器,每一次+1

设计表的时候。

通常我们会新增一个字段(没有意义的字段)去做主键。不去做修改。

主键是int类型的,我们可以给他设置自动增长(假设插入一条记录的时候,主键没有认为的设置值。会自己顺序。去+1 生成新的内容,添加到主键这个字段中。),auto_increment

主键自增长:

id int primary key auto_increment;

唯一约束:不允许重复。 一个表里可以添加多个唯一约束。

列名 类型(长度)unique;

非空约束:不允许为空。 表示该列的内容不允许为空。

列名 类型(长度) not null,

唯一和主键约束的区别

1、唯一约束可以是空(null)。 但是主键约束不能为空

2、一张表中只能有一个主键,但是唯一约束可以有多个。

1.3.3 主键约束详解

列级约束

表级约束(联合主键)

1.3.4 创建完表后,添加主键

alter table student add primary key(id);

1.3.5 给表添加约束

create table employee(
  id int primary key auto_increment,
  name varchar(32) not null unique, 
  gender varchar(10),
  birthday date,
  job varchar(30),
  salary double not null
);

1.3.6 创建表添加注释

create table employee(
  id int primary key auto_increment comment '编号',
  name varchar(32) not null unique comment '姓名', 
  gender varchar(10) comment '性别',
  birthday date comment '生日',
  entry_date date comment '入职日期',
  job varchar(30) comment '工作',
  salary double not null comment '薪水'
);

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Matlab】ELM极限学习机时序预测算法(附代码)

资源下载: https://download.csdn.net/download/vvoennvv/88681649 一,概述 ELM(Extreme Learning Machine)是一种单层前馈神经网络结构,与传统神经网络不同的是,ELM的隐层神经元权重以及偏置都是随机产生的…

tecplot360 提取某一点随时加变化的参数

tecplot360 提取某一点随时加变化的参数 效果过程录制宏打开所有数据(都进来所有的data数据) 效果 如下,红点处随时间变化的温度曲线 过程 简单理解就是将所有计算的data帧中固定点的参数取出来 所以先录制宏,然后应用宏自动取…

大模型时代下AIGC新浪潮

大模型时代下AIGC新浪潮 文章目录 大模型时代下AIGC新浪潮1. **相关概念**2. **迎接大模型时代**3. **ChatGPT引爆AIGC产业**4. **从产业链宏观看AIGC**1. **上游:基础层**2. **中游:技术层/模型层**1. **模型层介绍**2. **预训练大模型分类与介绍** 3. …

品优购实战案例

1. 开发工具 VScode 、Photoshop(fw)、主流浏览器(以Chrome浏览器为主) 2. 技术栈  利用 HTML5 CSS3 手动布局,可以大量使用 H5 新增标签和样式  采取结构与样式相分离,模块化开发  良好的代码规范有…

js常用事件演示

目录 JS事件的具体方法 窗口事件 表单事件 键盘事件 鼠标事件 知识小拓展 JS事件的具体方法 我们用到JavaScript的时候js的事件就显得特别重要了 事件名说明onsubmit当表单提交时触发该事件onclick鼠标单击事件ondblclick鼠标双击事件onblur元素失去焦点onfocus元素获得…

Eureka服务注册与发现中心

简介 Spring Cloud封装了Netflix 公司开发的Eureka模块来实现服务治理 在传统的RPC远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现…

打印菱形和金字塔类型(总结)

首先,在之前的学习中,我们了解了菱形的打印,今天我们来对金字塔和菱形这类打印图形的问题,我们来做一个总结。 这个总结的来源是这今天做了一道题 这道题的答案如下 这个题做起来并不难,拓展到这类问题中,…

【驱动序列】简单聊聊开发驱动程序的缘由和驱动程序基本信息

大家好,我是全栈小5,欢迎来到《小5讲堂》,这是《驱动程序》专栏序列文章。 这是2024年第4篇文章,此篇文章是结合了C#知识点实践序列文章,博主能力有限,理解水平有限,若有不对之处望指正&#xf…

面向对象(类和对象,对象内存图,成员变量和局部变量,封装,构造方法)

1. 类和对象 1.1 类和对象的理解 客观存在的事物皆为对象 ,所以我们也常常说万物皆对象。 类 类的理解 类是对现实生活中一类具有共同属性和行为的事物的抽象类是对象的数据类型,类是具有相同属性和行为的一组对象的集合简单理解:类就是对…

cJSON代码解读

1、背景 cJSON用了很久,但是对它一直不太了解。这次向添加对long long类型的支持,一直出问题。因为有以前添加两位小数float的经历,我觉得会很轻松,没想到翻车了。于是有了这边文档,阅读了部分博主对cJSON的解析&…

第二十七章 正则表达式

第二十七章 正则表达式 1.正则快速入门2.正则需求问题3.正则底层实现14.正则底层实现25.正则底层实现36.正则转义符7.正则字符匹配8.字符匹配案例19.字符匹配案例211.选择匹配符(|)12.正则限定符{n}{n,m}(1个或者多个)*(0个或者多…

OpenGL FXAA抗锯齿算法(Qt,Consloe版本)

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 之前已经提供了使用VCG读取Mesh的方式,接下来就需要针对读取的网格数据进行一些渲染操作了。在绘制Mesh数据时总会遇到图形的抗锯齿问题,OpenGL本身已经为我们提供了一种MSAA技术,但该技术对于一些实时渲染性能有…

软件测试/测试开发丨Pytest 测试框架学习笔记

前言 自动化测试前,需要提前准备好数据,测试完成后,需要自动清理脏数据,有没有更好用的框架?自动化测试中,需要使用多套测试数据实现用例的参数化,有没有更便捷的方式?自动化测试后…

​iOS实时查看App运行日志

目录 一、设备连接 二、使用克魔助手查看日志 三、过滤我们自己App的日志 📝 摘要: 本文介绍了如何在iOS iPhone设备上实时查看输出在console控制台的日志。通过克魔助手工具,我们可以连接手机并方便地筛选我们自己App的日志。 &#x1f4…

6个Python大礼包,请查收!

呕心沥血整理出来和视频相配套的笔记文档,搭配起来,学习事半功倍,赶紧收藏起来!!! 一丶90部Python基础视频教程 基础很重要,打好基础事半功倍,只要基础打的好,才能顺利…

Nginx 反向代理负载均衡

Nginx 反向代理负载均衡 普通的负载均衡软件,如 LVS,其实现的功能只是对请求数据包的转发、传递,从负载均衡下的节点服务器来看,接收到的请求还是来自访问负载均衡器的客户端的真实用户;而反向代理就不一样了&#xf…

vue保姆级教程----深入了解 Vue Router的工作原理

📢 鸿蒙专栏:想学鸿蒙的,冲 📢 C语言专栏:想学C语言的,冲 📢 VUE专栏:想学VUE的,冲这里 📢 CSS专栏:想学CSS的,冲这里 &#x1f4…

算法与人生 揭秘C语言中高效搜索的秘诀——二分查找算法详解

引言,少年们,大家好。在这里祝大家元旦快乐,我是博主那一脸阳光,今天来介绍二分查找 在计算机科学领域,搜索算法是数据处理和问题解决的重要工具之一。其中,**二分查找算法(Binary Search&#…

Python 正则表达式

文章目录 第1关:正则表达式基础知识第2关:re 模块中常用的功能函数(一)第3关:re 模块中常用的功能函数(二) 第1关:正则表达式基础知识 编程要求 根据提示,补全右侧编辑器…

三菱MR-JE伺服脉冲轴应用参数设置

三菱MR-JE伺服在脉冲轴控制上的应用,常用参数设置如下: 1、常用参数 未完...