MySQL学习笔记3: MySQL数据库基础
目录
- 前言
- 目标
- 数据库操作(针对database 的操作)
- 1. 创建数据库 create database 数据库名;
- 2. 查看数据库 show databases;
- 3. 选中数据库 use 数据库名;
- 4. 删除数据库 drop database 数据库名;
- mysql中支持的数据类型
- 1. 数值类型: NUMERIC(M,D)
- 2. 字符串类型: VARCHAR(SIZE)
- 数据库的 表 操作(前提都是要选中数据库)
- 1. 创建表 create table 表名(列名 类型 列名 类型 ...);
- 2. 查看有哪些表 show tables;
- 3. 查看表的结构 desc 表名;
- 4. 删除表 drop table 表名;
前言
操作使用 MySQL 需要用到一种专门的编程语言: SQL (和 Java, C++ 是同类的)
这里需要注意的是:MySQL 是一个数据库软件,SQL 是一个编程语言,操作 MySQL 需要用到 SQL, 操作其他数据库也会用到这个语言
目标
- 数据库的操作:创建数据库,删除数据库
- 常用数据类型 (数据类型我只列举了一两个呜呜)
- 表的操作:创建表,删除表
数据库操作(针对database 的操作)
数据库操作,此处 数据库 指的是 数据集合, 是逻辑上的概念, 一个 mysql 服务器上,有多个这样的数据集合.
1. 创建数据库 create database 数据库名;
create database 数据库名 charset utf8; (create, database 都是SQL 中的关键字,数据库名以字母数字下划线随便起,但是不能和关键字重复,每个语句这里带有英文分号 ; 结尾)

成功案例:

注意:一个服务器上 数据库的名字,是不能重复的
例子:

创建数据库的时候,还可以同时设置一个字符编码,对于数据库存储中文有一定的帮助
因为 mysql 5. 默认的字符集是"拉丁文"无法直接存储中文的,创建数据库的时候手动指定 utf8 的字符集
mysql 这里指定的字符集还有一种写法: utfmb4 这是mysql 专有的,因为 mysql 的utf8不是完全体,有些内容缺失了(比如emoji),
utf8mb4 是完整版本的 utf8
例子:

指令集: 比如不同的编码方式,一个汉字需要用不同的字节数保存, 使用不同的字符集,编码方式也不同.计算机存储的是"二进制数据"编码就是用数字表示字符 (比如ASCII码)
现在比较常见的中文编码方式主要有两种: utf8和gbk码表
- GBK (Windows 简体中文版,默认使用的字符编码),在 VS 上写 C 语言代码,可以看到一个汉字占 2 个字节,这种表示方式有一定缺陷,2个字节只能表示 6w 多个不同的字符,常用汉字 4k 个,但算上生僻字,总数就 6w 了.
- utf8 更通用的编码方式, 变长编码,一个utf8的字符,可能是1个字节,2个字节,3个字节,4个字节…utf8能表示全世界任何一种语言文字,utf8如果用来表示汉字,一般就是 3 个字节
- java 的 char 使用的是另外一种编码,unicode, gbk,utf8,unicode 是三种编码,也就是说,同一个汉字会有三种不同的数字表示,char 使用unicode 是没问题的, 但是String 就无法使用 unicode, Java String 默认也是 utf8
- utf8 和 unicode 是有关系的,如果现在有一组汉字,想把这一组汉字,通过网络传输/保存到文件中,势必就需要把汉字内部的编码,一个字节一个字节的进行传输/存储,在这种场景下, unicode 就寄了, 因为把多个 unicode 的字符编码的数据,按照字节挨在一起之后,然后就区分不出来,从哪到哪是一个完整的汉字了.utf8 就相当于为了解决 unicode 这个问题而产生的

2. 查看数据库 show databases;
查看当前服务器有哪些数据库?
show databases;
一个数据库服务器,可以有多个数据库,使用 s 复数形式来描述

这里有些数据库是系统自带的,有些是我后来手动创建的
testdemo就是刚才创建出来的新鲜的数据库
test是之前创建出来的数据库
information_schema, mysql, performance_schema, sys是系统自带的数据库,这些数据库维护了 mysql 内部的一些相关信息,不去修改他们

3. 选中数据库 use 数据库名;
use 数据库名;
数据库服务器上,有多个数据库,进行后续的表操作的时候,就需要先指定你要操作哪个数据库.

4. 删除数据库 drop database 数据库名;
drop database 数据库名;

删除数据库是一个非常危险的操作,一旦删掉之后,数据就没了.
如果你删除的是一个比较重要的生产环境的数据,就非常危险
工作中会接触到的几套环境:
- 办公环境: 发一个电脑 笔记本/台式机,进行日常办公使用的机器,配置比较低,用来通过通讯软件和其他同事交流,开一些会议,发邮件,写PPT等,配置像是 8c 16G 512G
- 开发环境: 写代码,编译代码,简单的运行代码,有些公司,开发环境就是办公环境(开发的项目比较简单),也有些公司,开发环境需要配专门的机器(服务器) 配置像是 28c 128G NT ,这样的服务器启动一下就要几十个GB的内存,在自己的电脑跑是不现实的
- 测试环境: 把写好的代码进行测试时候使用的环境,配置像是 28c 128G NT
- 生产环境: 办公,开发和测试环境统称为线下环境,生产环境也叫做线上环境,生产环境上面部署的程序,是可以直接被外面的用户访问到的,比如打开一个搜索引擎,在看到搜索结果的这个过程中访问了搜索引擎的生产环境的服务器,服务器经过运算返回结果.往往生产环境的配置是最高的,配置像是 56c 256G N T ,这样的机器可能还会有很多台.如果用户多了,对于机器的压力就比较大,每个用户进行一次访问,服务器都是需要消耗一定的硬件资源来进行计算的,包括但不限于cpu,内存,硬盘,网络宽带…如果同一时刻的用户访问量非常大,消耗的总资源超过了机器能够提供的资源上限,这个时候,服务器可能就挂了(网页刷不出来,甚至就卡死了…)这种情况就是高并发,为了应对高并发的情况,可以添加更多的机器解决,因此生产环境上所涉及到的甚至几百台服务器所构成了分布式系统(集群)
mysql中支持的数据类型
mysql是关系型数据库,是按照 数据表的方式来组织数据的,数据表中的每一列都会有具体的类型,下面说明一些比较重要的数据类型
1. 数值类型: NUMERIC(M,D)
float 和 double 不能精确保存,因此比较两个浮点数,不能使用 == ,而是需要通过作差, 小于一个误差值的形式(IEEE 754 标准)
在MySQL中,DECIMAL 和 NUMERIC 可以看作是相同的数据类型。事实上,这两者是可互换的,它们都用来存储精确的数值,这些数值有固定的小数位。这很重要,尤其是在处理财务数据时,比如货币,其中精度非常关键。
DECIMAL和NUMERIC类型允许用户定义精确度和小数位。格式可以表示为DECIMAL(M, D)或NUMERIC(M, D),其中M是数字的最大总位数(精度),D是小数点后的位数(标度)。如果没有定义D,默认是0。
例如,DECIMAL(10, 2)可以存储最大为99999999.99的数字,其中有8位在小数点前,2位在小数点后。
DECIMAL不是按照 IEEE 754 的方式来表示的,而是类似于字符串的方式来表示的,需要付出更多的空间,运算的时候也会消耗更多的时间,但是保存的数据是精确的
2. 字符串类型: VARCHAR(SIZE)
size表示的是该字符串类型的数据能表示的最大长度
数据库的 表 操作(前提都是要选中数据库)
关系型数据库里边的存储结构先是一个数据库服务器,上面有很多数据库,每一个数据库都是逻辑上的数据集合,每一个数据库中都包含数据表
数据表 就是存储数据的基本单位
针对数据表的操作,一定是要先选中数据库 (use 数据库名;)
数据表有很多列,每一列都会有具体的类型
1. 创建表 create table 表名(列名 类型 列名 类型 …);
创建表的时候,必须要描述出表包含哪些列,每一列的类型,每一列的名字…后续往表里放的数据,也要遵守这里的规则,这是关系型数据库的基本要求
明确了列的类型,就可以更方便的对数据的值进行检查和校验

写sql的时候,可以分成多行

遇到 ; 才是一个完整的 sql, 在 ; 之前换行,就是换行操作

2. 查看有哪些表 show tables;

3. 查看表的结构 desc 表名;
desc => describe
就是查看一个表里面有哪些列,列的名字和类型啥的…

Field表示有哪些列,Null如果是YES表示这个格子没有填,是空的,Default是默认值,这里默认为NULL
4. 删除表 drop table 表名;

相关文章:
MySQL学习笔记3: MySQL数据库基础
目录 前言目标数据库操作(针对database 的操作)1. 创建数据库 create database 数据库名;2. 查看数据库 show databases;3. 选中数据库 use 数据库名;4. 删除数据库 drop database 数据库名; mysql中支持的数据类型1. 数值类型: NUMERIC(M,D)2. 字符串类…...
GB/T 17640-2023 长丝机织土工布检测
长丝机织土工布是指以合成纤维长丝为原料织制而成的土工布,按纤维品种分为涤纶、丙纶、锦纶 等长丝机织土工布;按用途分为反滤布、复合用基布、管袋布、模袋布等。 GB/T 17640-2023 长丝机织土工布测试项目: 测试要求 测试标准 经向抗拉强…...
MedicalGPT 训练医疗大模型,实现了包括增量预训练、有监督微调、RLHF(奖励建模、强化学习训练)和DPO(直接偏好优化)
MedicalGPT 训练医疗大模型,实现了包括增量预训练、有监督微调、RLHF(奖励建模、强化学习训练)和DPO(直接偏好优化)。 MedicalGPT: Training Your Own Medical GPT Model with ChatGPT Training Pipeline. 训练医疗大模型,实现了包括增量预训练、有监督微…...
UE4 C++联网RPC教程笔记(一)(第1~4集)
UE4 C联网RPC教程笔记(一)(第1~4集) 前言1. 教程介绍与资源2. 自定义 Debug 功能3. Actor 的复制4. 联网状态判断 前言 本系列笔记将会对梁迪老师的《UE4C联网RPC框架开发吃鸡》教程进行个人的知识点梳理与总结,此课程…...
备战蓝桥杯 Day11(滚动数组优化+完全背包)
01背包的滚动数组优化 【题目描述】 经典0—1背包问题,有n个物品,编号为i的物品的重量为w[i],价值为c[i],现在要从这些物品中选一些物品装到一个容量为m的背包中,使得背包内物体在总重量不超过m的前提下价值尽量大。 #include&…...
Java SE 入门到精通—4.抽象类与接口【Java】
抽象类 同接口一样,用来约束子类,限制子类必须拥有某些方法,比普通类多了个抽象方法,用抽象方法该类必为抽象类 概念 没有具体的对象,具体的方法的一个类 abstract关键字声明为抽象类/方法 一个类中有抽象方法则该…...
Python 开发转 Java 简易路线 - 更新中
有了 Python 开发基础,Java 的内容都可以快速过一遍,复杂地方跟着写一遍。 一、基础 1、Java 基础:尚硅谷 - Java基础 全部快速过一遍, 2、数据库:略。 着重 mysql 高级部分(针对面试)&…...
Python编程语言学习
1.Python 特点 Python是一种简单、易读、易学和高效的编程语言,具有以下特点: 简单易学:Python采用清晰简洁的语法,注重代码的可读性和可维护性,使得初学者能够快速上手并编写出清晰的代码。 面向对象:Py…...
Cartographer框架简述
catographer框架分为前端和后端 前端包括雷达数据处理;位姿预测;扫描匹配和栅格地图更新。 后端包括后端:线程池任务与调度;向位姿图添加节点,计算节点的子图内约束和子图间约束(回环检测)&…...
适用于 Linux、Windows 和 macOS 的免费 ONLYOFFICE 桌面应用程序
前言: 最近也是发现了一款特别好用的免费ONLYOFFICE 桌面应用程序忍不住分享给大家,这款编辑器能够打开、阅读和编辑多种文件类型,包括.docx文档、.pptx幻灯片和.xlsx表格等开放XML格式的Office文档。此外,ONLYOFFICE桌面编辑器还…...
C++面向对象程序设计-北京大学-郭炜【课程笔记(四)】
C面向对象程序设计-北京大学-郭炜【课程笔记(四)】 1、this指针1.1、this指针的作用1.2、this指针和静态成员函数 2、静态成员变量和静态成员函数2.1、基本概念2.2、基本概念总结2.3、如何访问静态成员2.4、静态成员变量的使用场景(重要&…...
前端构建效率优化之路
项目背景 我们的系统(一个 ToB 的 Web 单页应用)前端单页应用经过多年的迭代,目前已经累积有大几十万行的业务代码,30 路由模块,整体的代码量和复杂度还是比较高的。 项目整体是基于 Vue TypeScirpt,而构…...
react实现拖拽的插件
插件一:dnd-kit 插件官网链接https://docs.dndkit.com/introduction/installation 插件二:react-beautiful-dnd https://github.com/atlassian/react-beautiful-dnd/tree/master 两个插件的区别: 插件一可以做到从区域A拖住到区域B 插件二…...
解决Uncaught SyntaxError: Cannot use import statement outside a module(at XXX)报错
报错原因:这个错误通常是因为你正在尝试在一个不支持 ES6 模块语法的环境中使用 import 语句。这可能是因为你的代码是在一个只支持 CommonJS 或 AMD 模块系统的环境中运行的,或者你的代码运行的环境没有正确配置以支持 ES6 模块。如果是在浏览器环境&am…...
PHP如何利用post与get方式传值接收数据
目录 一、POST传值1. 使用curl库发送 POST 请求:2. 使用file_get_contents()函数发送 POST 请求:3. 使用stream_socket_client()函数发送 POST 请求:4. 利用from表单提交数据: 二、GET传值1. 使用http_build_query()函数构建 URL …...
在Mac上搭建MongoDB环境
最近工作中需要装MongoDB环境,搭建过程中遇到了一些问题,在这里记录一下安装MongoDB环境的方法以及问题的解决方法。有两种安装MongoDB的方法:brew安装和手动安装。 目录 使用Homebrew安装MongoDB 手动安装MongoDB(不使用Homebr…...
第三十九天| 62.不同路径、63. 不同路径 II
Leetcode 62.不同路径 题目链接:62 不同路径 题干:一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “…...
提高代码质量的 10 条编码原则
提高代码质量的 10 条编码原则 本文转自 公众号 ByteByteGo,如有侵权,请联系,立即删除 今天来聊聊提高代码质量的 10 条编码原则。 软件开发需要良好的系统设计和编码标准。我们在下图中列出了 10 条良好的编码原则。 01 遵循代码规范 我们…...
SHERlocked93 的 2017 年终总结
回家的路上有点无聊,简短回顾一下2017年的得失收获 开始两个月3月到5月用C#完结了一个烂尾的wpf小项目,对自己前半年的.net生涯也算是一个句号(虽然不知道最后有没有采用),后面由于项目组转变技术栈,选择了…...
【FreeRTOS基础入门】任务通知
文章目录 前言一、任务通知介绍1.1 任务通知怎么通信1.2 任务通知与其他通信方式的区别1.3 优势及限制任务通知的优势任务通知的限制 1.4 内部原理 二、任务通知的使用2.1 发出与接收通知简化版2.1 发出与接收通知专业版 总结 前言 FreeRTOS 提供了丰富而灵活的任务通知机制&a…...
使用分级同态加密防御梯度泄漏
抽象 联邦学习 (FL) 支持跨分布式客户端进行协作模型训练,而无需共享原始数据,这使其成为在互联和自动驾驶汽车 (CAV) 等领域保护隐私的机器学习的一种很有前途的方法。然而,最近的研究表明&…...
UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...
深入理解JavaScript设计模式之单例模式
目录 什么是单例模式为什么需要单例模式常见应用场景包括 单例模式实现透明单例模式实现不透明单例模式用代理实现单例模式javaScript中的单例模式使用命名空间使用闭包封装私有变量 惰性单例通用的惰性单例 结语 什么是单例模式 单例模式(Singleton Pattern&#…...
使用van-uploader 的UI组件,结合vue2如何实现图片上传组件的封装
以下是基于 vant-ui(适配 Vue2 版本 )实现截图中照片上传预览、删除功能,并封装成可复用组件的完整代码,包含样式和逻辑实现,可直接在 Vue2 项目中使用: 1. 封装的图片上传组件 ImageUploader.vue <te…...
《基于Apache Flink的流处理》笔记
思维导图 1-3 章 4-7章 8-11 章 参考资料 源码: https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...
【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...
保姆级教程:在无网络无显卡的Windows电脑的vscode本地部署deepseek
文章目录 1 前言2 部署流程2.1 准备工作2.2 Ollama2.2.1 使用有网络的电脑下载Ollama2.2.2 安装Ollama(有网络的电脑)2.2.3 安装Ollama(无网络的电脑)2.2.4 安装验证2.2.5 修改大模型安装位置2.2.6 下载Deepseek模型 2.3 将deepse…...
视觉slam十四讲实践部分记录——ch2、ch3
ch2 一、使用g++编译.cpp为可执行文件并运行(P30) g++ helloSLAM.cpp ./a.out运行 二、使用cmake编译 mkdir build cd build cmake .. makeCMakeCache.txt 文件仍然指向旧的目录。这表明在源代码目录中可能还存在旧的 CMakeCache.txt 文件,或者在构建过程中仍然引用了旧的路…...
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join 1、依赖1.1、依赖版本1.2、pom.xml 2、代码2.1、SqlSession 构造器2.2、MybatisPlus代码生成器2.3、获取 config.yml 配置2.3.1、config.yml2.3.2、项目配置类 2.4、ftl 模板2.4.1、…...
