当前位置:网站首页>MySQL——基础知识
MySQL——基础知识
2022-07-30 17:53:00 【Xiaolock830】
接下来的几篇博客将介绍MySQL的基础知识和相关使用方法,然后再回到Java,介绍JavaEE的知识
什么是数据库
受硬件的技术影响,我们不可能将所有的文件存储在计算机的内存中。并且,我们还需要考虑存储的安全问题,存储数据的增删查找的效率问题等。而数据库是用来管理海量数据的一款软件
数据库的分类
关系型数据库
由关系模型(二维表格模型)来组织数据,常见的实现关系型数据库的软件有
- Oracle
- MySQL
- SQL Server
使用了SQL,支持事务,也支持复杂操作,对于海量数据的增删查改的效率低,基本的结构类似exile表格,用于业务方面的OLTP系统(联机事务处理)
非关系型数据库
没有关系,可分为如下类别:
- 基于键值对的
- 基于文档的
- 基于列族的
- 基于图形的
不支持事务和复杂操作,对海量数据增删查改的效率低,用于数据的缓存
SQL的分类
- 维护存储数据的结构
例如:create,drop,alter - 对数据进行操作的关键字
例如:insert,update,delete - 关于权限管理和事务的关键字
例如:grant,revoke,commit
MySQL中的数据类型
数据类型 | 大小 | 对应JAVA中的类型 |
---|---|---|
bit(1-64) | 指定的位数,默认是1 | boolean |
tinyint | 1 | byte |
smallint | 2 | short |
int | 4 | int |
bigint | 8 | long |
float(长度,位数) | 4 | float |
double(长度,位数) | 8 | double |
decimal(长度,位数) | 长度和位数最大值加2 | bigdecimal |
numeric(长度,位数) | 长度和位数最大值加2 | bigdecimal |
varchar(长度) | 0-65536 | String |
text | 0-65535 | String |
mediumtext | 0-16777215 | String |
blob | 0-65535 | byte[] |
datetime | 8 | java.util.Date,java.sql.Timestamp |
timestamp | 4 | java.util.Date,java.sql.Timestamp |
需要注意的是,MySQL中支持unsigned,也就是无符号数,但是并不支持,因为也许会引发bug
对数据库的操作
需要注意的是,MySQL中的代码不区分大小写,我个人更倾向于小写,而和其他的编程语言一样,在每个代码的结束都有;
显示数据库
show databases;
可以显示当前用户底下有哪些数据库
创建数据库
create database 数据库名字;
由于不能创建同名的数据库,我们用以下语法可以进行判定系统中有没有我们要创建的数据库,如果没有就创建
create database if not exists 数据库名字;
在之前的博客中讲到不同的语言有不同的编码字符集,而不同的字符集对各种语言的支持不一样,例如ascii码不支持中文,而我们可以在创建数据库时指定要使用的字符集
create database 数据库名字 character set utf8mb4;
使用数据库
我们只能对单一的数据库进行操作,在相关代码执行前,应该先选中我们要使用的数据库
use 数据库名;
删除数据库
️ 这是一个非常危险的操作,网上报道过程序员删库跑路被判刑的相关新闻,因此在公司中操作一定要小心谨慎
drop database 名字
和创建数据库一样,我们也可以判定一下要删除的数据库存不存在
drop database if exists 名字;
对表的操作
有了数据库,我们就可以选中数据库,在其中创建表
创建表
需要注意的是,MySQL和C,java不同,数据的类型要放到内容的后面
create table 表名字(表头1 类型,表头2 类型....);
查看数据库中的所有表
和查看所有数据库类似
show tables;
查看表的结构
我们可以通过如下代码查看表的表头名,类型,是否允许为空,索引类型,默认值,扩充
desc 表名;
注释
我们可以用comment给表中增加字段说明
create table 表名字(表头1 类型 commit xxx,表头2 类型....);
删除表
和删除数据库的操作相同
drop table 表名
也同样可以进行if exists的操作
边栏推荐
- What are the applications of X-rays?
- js中的基础知识点 —— BOM
- 【HMS core】【Analytics Kit】【FAQ】如何解决华为分析付费分析中付款金额显示为0的问题?
- 【Cloud Store Announcement】Notice of Help Center Update on July 30
- 躲避雪糕刺客?通过爬虫爬取雪糕价格
- 图解LeetCode——11. 盛最多水的容器(难度:中等)
- Promise entry to proficient (1.5w word detailed explanation)
- C陷阱与缺陷 第6章 预处理器 6.3 宏并不是语句
- BI报表与数据开发
- 沃尔沃中国的年中总结,在“安全感”中寻找未来
猜你喜欢
windwons 下GPU环境和pytorch安装
宝塔搭建PHP自适应懒人网址导航源码实测
PyTorch 猫狗分类源代码及数据集
基础架构之Mongo
Prometheus 基本概念
针不戳,数据库性能优化八大方案。
网络基础(二)-Web服务器-简介——WampServer集成服务器软件之Apache+MySQL软件安装流程 & netstat -an之检测计算机的端口是否占用
ERROR 2003 (HY000) Can't connect to MySQL server on 'localhost3306' (10061)Solution
LeetCode 952. 按公因数计算最大组件大小
沃尔沃中国的年中总结,在“安全感”中寻找未来
随机推荐
SQL存储过程详解
DevEco Studio3.0下载失败,提示An unknown error occurred
【解决】关于 Unity Hub 获取许可证失败 或 无响应导致无法开发的问题
un7.30:linux——如何在docker容器中安装MySQL?
Basic knowledge points in js - BOM
Mathematical Principles of Graph Convolutional Neural Networks——A Preliminary Study on Spectral Graph Theory and Fourier Transform
数据库系统原理与应用教程(068)—— MySQL 练习题:操作题 90-94(十二):DML 语句练习
Moralis去中心化Web3应用开发教程
JMeter Notes 4 | JMeter Interface Introduction
LayaBox---TypeScript---基础数据类型
2022年杭电多校第2场 1001 Static Query on Tree(树链剖分+哈希表差分
17.机器学习系统的设计
荐书 | 推荐好评如潮的3本数据库书籍
952. 按公因数计算最大组件大小 : 枚举质因数 + 并查集运用题
第十六期八股文巴拉巴拉说(MQ篇)
C陷阱与缺陷 第6章 预处理器 6.3 宏并不是语句
想要写出好的测试用例,先要学会测试设计
Promise entry to proficient (1.5w word detailed explanation)
宽带射频放大器OA4SMM4(1)
Vulkan与OpenGL对比——Vulkan的全新渲染架构