当前位置: 首页 > news >正文

[MySQL]基本数据类型及表的基本操作

哈喽,大家好!我是保护小周ღ,本期为大家带来的是 MySQL 数据库常用的数据类型,数据表的基本操作:创建、删除、修改表,针对修改表的结构进行了讲解,随后是如何向数据表中添加数据,浅浅的提了一下表中数据的查询,更多相关知识敬请期待:保护小周ღ *★,°*:.☆( ̄▽ ̄)/$:*.°★*


一、常用的数据类型

1.1 数据库表的列类型

数值 1 2 3.14
  • tinyint 十分小的数据 1个字节

  • smallint 较小的数据 2个字节

  • mediumint 中等大小的数据 3个字节

  • int 标准的整数 4个字节

  • big 较大的数据 8个字节

  • float 浮点数 4个字节

  • double 浮点数 小数 8个字节(精度问题)

  • decimal 字符串形式的浮点数 (金融计算的时候一般使用)

字符串
  • char 固定大小字符串 0-255 char(5) 00001

  • varchar 可变字符串 0-65535 varchar(5) 1

  • tinytext 微型文本 2^8 - 1

  • text 文本串 2^16 -1 保存大文本

时间日期
  • date YYYY-MM-DD,日期 (year,month,day)

  • time HH: MM : SS 时间格式(hour:minutes,seconds)

  • datetime YYYY-MM-DD HH: MM:SS (年月日,时分秒)最常用的时间格式

  • timestamp 时间戳, 1970.1.1到现在的毫秒数!

  • year 年份

null
  • 没有值, 未知

  • 注意,不要使用null进行运算,结果肯定为null


  1. 上面看到的这类基本数值数据类型都是有符号的,MySql 也是支持无符号的数据类型,unsigned 作为前缀,但是 官方也建议无符号类型不建议使用,特定情况下会产生很严重的误差,例如,a - b, b > a,但是由于没有符号限制,两者相减反而会产生一个很大的数,在MySql 后续的版本中也不会在支持无符号类型了。

  1. 在使用浮点型数据时,最好选择decimal ,他的精度比 float 、double 更高,语法: decimal(M,N) M : 整个数据的总长度,N:数据小数的位数。例如: 3.14, M = 3, N = 2; 在表示货币的时候我们可以采用 int 类型,这样就不会有精度的问题,采用”分“为单位。例 :123,表示 1.23 元。

  1. 我们在使用时间类型是,不知道该用什么样的格式插入时间,在插入时间的时候,是通过特定的字符串来表示时间日期的,例如: "2023-02-9 16:12:00", 对于字符串来讲 英文单引号或者双引号都可以。日期年月日之间用 '-' 减号连接,与时间之间隔一个空格,时间之间用 ':' 连接。以这样的形式输入的字符串,服务器就会识别为时间。如果我们想使用当前系统时间,SQL 提供了一个返回当前系统时间的函数 now(),这个函数赋值即可。


二、数据表的基本操作

书接上篇,我们已经学习了如何操作数据库,本篇学习如何操作数据表,在操作数据表的时候,需要选中数据库;

2.1 创建和删除表

声明:本篇博客讲述的是基础操作,关于数据库的字段属性尽请期待下一篇博客。

基础语法 :

create table table_name (
`字段名` [属性] [索引] [注释],`字段名` [属性] [索引] [注释],...`字段名` [属性] [索引] [注释],…… ……
);

那么在创建一个表之前呢,也可以判断一下这个表是否存在,就像创建数据库时的操作一样。

create table if not exists student (……
);

可以使用 comment 增加字段说明,只是给 sql语句提供一个注释作用,在创建的时候。

例如:

create table stu_test (
id int,
name varchar(20) comment '姓名',
password varchar(50) comment '密码',
);

例题:

-- 创建学生表(列,字段) 使用SQL创建

-- 学号int 姓名 varchar(10),varchar性别sex('男','女'),身高decimal(3,2),加入时间 datetime。

-- 字符串使用 单引号括起来!

-- 所有语句后面加,(英文的),最后一个不用加

目前我们已经创建好了一个student 的数据表,接下来的操作是查看一下这个表的结构。

desc teble_name;

desc ->describe 的缩写,描述一个表的结构。


创建了一个表,那自然要学习如何删除一个表,。

删除表(drop):(如果表存在再删除)

drop table if exists student;
--当然最稳妥的操作是 指定数据库之后再选择表,这样就可以避免误操作
drop table if exists school.student;
--这样删也是可以的,但是更容易报错
drop table student; 

因为我们是student 数据表是创建在 school 数据库里面,然后可以通过 ‘.’这个符号来约束一下,避免误操作,这也是一种精确表示的方法。

==所有的创建和删除操作,尽量加上判断以免报错==


2.2 修改表的结构(alter)

-- 修改表结构

依据上表 student 表为例,如果我们在创建好表的结构之后,难免在会有所纰漏,比如说少添加了一个字段,又或者是发现某个字段不合适需要删除,还有修改字段属性等等……

2.2.1-- 添加字段

student 表 新增一个叫做 telephone (手机号)的字段,它的类型是可变字符串。

语法:add 是关键字

alter table 【表名】 add 【新增字段名】【属性】 ;

2.2.2 -- 修改字段 (注意本条语句不修改字段名)

假如我们发现表中的telephone (手机号)的字段 属性的长度给少了,所以我们需要修改一下这个字段。

语法:modify 是关键字

alter table 【表名】 modify 【字段名】【修改后的属性】 ;

2.2.3 -- 修改字段名

假如我们发现表中的某个字段的 字段名没取好名,也是可以修改的,例如将 sex 修改为 gender (性别)

语法: change 是关键字

alter table 【表名】 change 【原字段名】【修改后的字段名】【属性】 ;

2.2.4 -- 删除字段

这个就很好理解了,删除某个字段(列名), 本次删除 telephone 字段。

语法:

alter table 【表名】 drop 【字段名】;

2.2.5 -- 修改表名

将student 数据表 表名修改为 stud。

语法:关键字 rename

alter table 【表名】 rename 【修改后的表名】;

执行语句后表名已经被修改,以上操作,轻易不要操作,容易造成一系列的连锁反应(蝴蝶效应,动了一个表,可能需要修改多个表的数据,关系型数据库),在创建的时候就将表的结构计划好,尽可能的减少表结构的修改。


2.3 添加数据(insert into )插入

语法:

insert into 表名([字段名1,字段名2,字段名3])values('值1'),('值2)',('值3')...

into 其实可以不用写,可以根据个人意愿决定。

2.3.1-- 插入时匹配对应的值

这种方式插入数据,需要指定需要插入的列名(字段),然后根据列名(在记录没有约束的情况下)插入数据。

意思就是你可以只插入“李四" 独占一行。注意观察插入日期的格式。


2.3.2 -- 不声明字段新增数据,必须把所有字段的值都写上

此处使用now() 函数来插入日期时间。


2.3.3 -- insert语句后面可以加多个VALUES,可以添加多个数据

多行插入只需要写一个 values 即可,多行插入的性能也是优于 单行插入的,因为MySql 本质上就是客服端服务器的程序,客服端发出指令,服务器进行相应的处理,一行一行的插入意味着反复发送指令,这个点不知道大家能否能 get 到呢?


注意事项:

字段和字段之间使用英文逗号隔开
字段是可以省略的,但是后面的值必须要一一对应
可以同时插入多条数据,VALUES后面的值需要使用,隔开即可。
value,是一个具体的值,也可以是一个函数

2.4 基础查询

语法:

SELECT 字段,...FROM 表

以student 表为例。

-- 查询所有的员工 SELECT 字段 FROM 表

如果我们需要一次性查找所有的字段,其实不用讲所有字段全部列举出来,可以使用 ”*“ 来替代。

可以看出两者的结果是一样的。


-- 查询指定字段,ID + Name

-- 别名,给查询结果起一个名字 AS, 可以给字段取别名,也可以给表取别名

-- as可以加也可以不加

这样看起来舒服多了吧,哈哈,as 不加也可以运行,但是最好是加上,避免将别名看成字段。

-- 别名可以简化字段或者表的名称,更精准的输入

-- 给student表起别名为stu

不使用 as 也是可以的,在复杂的查询中,使用别名查询,能提升效率。


好了好了,关于查询就浅浅的说一一下啦,关于查询还有许多知识,一篇写不下,下篇博客将着重讲解查询语句。

至此,Mysql 系列的第二篇内容博主已经分享完了,希望对大家有所帮助,如有不妥之处欢迎批评指正。

本期收录于博主的专栏——Java & MySQL,适用于编程初学者,感兴趣的朋友们可以订阅,查看其它“MySQL 数据库以及Java JDBC 编程的相关知识”。

下一期:MySQL 字段的基本属性,数据表的修改、删除、然后重点—— 查询

感谢每一个观看本篇文章的朋友,更多精彩敬请期待:保护小周ღ *★,°*:.☆( ̄▽ ̄)/$:*.°★*

遇见你,所有的星星都落在我的头上……

相关文章:

[MySQL]基本数据类型及表的基本操作

哈喽,大家好!我是保护小周ღ,本期为大家带来的是 MySQL 数据库常用的数据类型,数据表的基本操作:创建、删除、修改表,针对修改表的结构进行了讲解,随后是如何向数据表中添加数据,浅浅…...

华为OD机试 - 好朋友(Python) | 机试题+算法思路+考点+代码解析 【2023】

好朋友 题目 在学校中 N个小朋友站成一队 第i个小朋友的身高为height[i] 第i个小朋友可以看到第一个比自己身高更高的小朋友j 那么j是i的好朋友 (要求:j > i) 请重新生成一个列表 对应位置的输出是每个小朋友的好朋友的位置 如果没有看到好朋友 请在该位置用0代替 小朋友…...

SAP ABAP用程序给用户增加SAP_ALL权限

给用户增加SAP_ALL的权限,报表可对basis与abap开发人员对用户权限管理的思路,谢绝用于其它用途,后果自负。 REPORT ZTESTCREATEUSER. data: l_USR04 LIKE USR04 , l_UST04 LIKE UST04 , l_PROFS LIKE USR04-PROFS , l_…...

stm32f407探索者开发板(二十)——独立看门狗实验

文章目录一、独立看门狗概述1.1 独立看门狗二、常用寄存器和库函数配置2.1 独立看门狗框图2.2 键值寄存器IWDG_KR2.3 预分频寄存器IWDG_PR2.4 重装载寄存器IWDG_RLR2.5 状态寄存器IWDG_SR2.6 IWDG独立看门狗操作库函数三、手写独立看门狗实验3.1 操作步骤3.2 iwdg.c3.3 iwdg.h3…...

C语言进阶(五)—— 多维数组

1. 一维数组 元素类型角度:数组是相同类型的变量的有序集合内存角度:连续的一大片内存空间在讨论多维数组之前,我们还需要学习很多关于一维数组的知识。首先让我们学习一个概念。1.1 数组名考虑下面这些声明:int a; int b[10];我们…...

06_MySQL多表查询

多表查询,也称为关联查询,指两个或更多个表一起完成查询操作。前提条件:这些一起查询的表之间是有关系的(一对一、一对多),它们之间一定是有关联字段,这个关联字段可能建立了外键,也…...

程序员赚钱指南,兼职社区招募

👨‍💻作者简介:大数据专业硕士在读,CSDN人工智能领域博客专家,阿里云专家博主,专注大数据与人工智能知识分享。 🎉专栏推荐:目前在写一个CV方向专栏,后期会更新不限于目…...

Qt-FFmpeg开发-实现录屏功能(10)

#音视频/FFmpeg #Qt Qt-FFmpeg开发-实现录屏功能💬 文章目录Qt-FFmpeg开发-实现录屏功能💬1、概述💥2、实现效果💨3、FFmpeg录屏代码流程👁️‍🗨️4、主要代码🤙5、完整源代码🤏更…...

JavaEE简单示例——动态SQL元素<where>

简单介绍: 在我们之前使用where关键字进行查询的时候,总是会在后面添加一个11恒等式,并且在每一个可能拼接的SQL语句前面都加上一个and关键字,防止当后续的所有条件都不满足的时候,where关键字在最后直接跟and的时候也…...

本地事务详解

1、事务的基本性质 数据库事务的几个特性:原子性(Atomicity )、一致性( Consistency )、隔离性或独立性( Isolation) 和持久性(Durabilily),简称就是 ACID;  原子性:一系列的操作整体不可拆分,要么同时成功&#x…...

e2e测试-Cypress 使用

● 官网 ● GitHub 一、安装 # npm npm install cypress --save-dev# yarn yarn add cypress --dev添加 npm 脚本: {"scripts": {"cypress:open": "cypress open"} }启动: npm run cypress:open二、编写测试 Cypress…...

20230222 【梳理】肿瘤检测 预处理+ML+DL

一、预处理 1、形态学【使图像中的重要部分更加可见,并消除MRI图像的琐碎部分。】 形态学操作是一种非线性操作,涉及在二值图像上移动一个窗口(或结构元素),以一种方式帮助增长图像(膨胀)或缩小图像(侵蚀)[30]。这种预处理技术更有用,特别是当MRI图像中存在不需要...

经典文献阅读之--MSC-VO(曼哈顿和结构约束VIO)

0. 简介 对于视觉里程计而言,在面对低纹理场景时,往往会出现退化的问题,究其原因是人造环境往往很难找到足够数量的点特征。而其他的几何视觉线索则是比较容易找到,在城市等场景中,通常表现出结构规律,如平…...

华为OD机试真题Python实现【字母计数】真题+解题思路+代码(20222023

字母计数 题目 给出一个只包含字母的字符串, 不包含空格,统计字符串中各个子字母(区分大小写)出现的次数, 并按照字母出现次数从大到小的顺序输出各个字母及其出现次数 如果次数相同,按照自然顺序排序,且小写字母在大写字母之前 🔥🔥🔥🔥🔥👉👉👉👉👉�…...

在中国市场,假如Teradata像Nutanix那样“退出操作”,谁来“接盘”呢?

【引言】:看它的选择,是数据仓库发展必然还是偶然呢?【全球存储观察 | 热点关注】前些天,将逐步结束在中国市场直接运营的Teradata引发了业界大量关注与讨论。作为全球数据仓库领域的绝对领导者,为什么会退…...

使用vs2022编译yolov5+tensorRT+cuda+cudnn代码进行混合编译

首先依赖有cuda、cudnn、tensorrt、protobuf,从Linux的代码直接移植过来这些库是没法使用的,需要下载对应win的下的版本,其中cuda、cudnn和tensorrt直接从官方下载即可,但是protobuf需要自己编译一下(protobuf3.11.4&a…...

记一次:request请求总结

前言:和前端联调的时候发现前端人员请求的方式不对,固做此总结问题:request请求方式有多少种?答:Java后端查看有8种,spring-web中的java枚举图如下而使用PostMan查看有15种,如下图GET&#xff0…...

2023年全国最新会计专业技术资格精选真题及答案2

百分百题库提供会计专业技术资格考试试题、会计考试预测题、会计专业技术资格考试真题、会计证考试题库等,提供在线做题刷题,在线模拟考试,助你考试轻松过关。 二、多项选择题 1.下列各项中,属于企业流动负债的有(&am…...

每日英语-20230221

TV series ˈsɪriːz 系列片 greate documentary 很棒的纪录片 menstruation ˌmenstruˈeɪʃn 生理期 sexuality ˌsekʃuˈləti 性关系 which is a worldwise project giving a voice to 2000 women across 50 different countries motherhood 母亲身份 financial indepen…...

学习系统编程No.4【环境变量】

引言: 北京时间:2023/2/20/22:15,昨天晚上,看了一晚上的cs:go,主要原因是因为我的好舍友,叫我开箱子,然后就不可言语,看了一晚上的开箱子和精彩剪辑,不过这个…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例

使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...

ffmpeg(四):滤镜命令

FFmpeg 的滤镜命令是用于音视频处理中的强大工具,可以完成剪裁、缩放、加水印、调色、合成、旋转、模糊、叠加字幕等复杂的操作。其核心语法格式一般如下: ffmpeg -i input.mp4 -vf "滤镜参数" output.mp4或者带音频滤镜: ffmpeg…...

HTML前端开发:JavaScript 常用事件详解

作为前端开发的核心,JavaScript 事件是用户与网页交互的基础。以下是常见事件的详细说明和用法示例: 1. onclick - 点击事件 当元素被单击时触发(左键点击) button.onclick function() {alert("按钮被点击了!&…...

vue3+vite项目中使用.env文件环境变量方法

vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...

Android第十三次面试总结(四大 组件基础)

Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: ​onCreate()​​ ​调用时机​:Activity 首次创建时调用。​…...

Python 包管理器 uv 介绍

Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...

推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)

推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...

Java毕业设计:WML信息查询与后端信息发布系统开发

JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息&#xff0…...

Modbus RTU与Modbus TCP详解指南

目录 1. Modbus协议基础 1.1 什么是Modbus? 1.2 Modbus协议历史 1.3 Modbus协议族 1.4 Modbus通信模型 🎭 主从架构 🔄 请求响应模式 2. Modbus RTU详解 2.1 RTU是什么? 2.2 RTU物理层 🔌 连接方式 ⚡ 通信参数 2.3 RTU数据帧格式 📦 帧结构详解 🔍…...