【MySQL】基础知识(一)

news2024/11/24 17:59:58

MySQL基础知识(一)

文章目录

  • MySQL基础知识(一)
    • 00 MySQL安装
    • 01 数据库介绍
      • 1.1 什么是数据库
      • 1.2数据库分类
    • 02 SQL分类
    • 03 数据库操作
      • 3.1显示数据库
      • 3.2创建数据库
      • 3.3选中数据库
      • 3.4删除数据库
    • 04 常用数据类型
      • 4.1数值类型
      • 4.2字符串类型
      • 4.3日期类型

00 MySQL安装

Windows下通过MySQL Installer安装MySQL服务

01 数据库介绍

1.1 什么是数据库

存储数据用文件就可以了,为什么还要弄个数据库?
文件保存数据有以下几个缺点:

  • 文件的安全性问题

  • 文件不利于数据查询和管理

  • 文件不利于存储海量数据

  • 文件在程序中控制不方便

数据库存储介质:

  • 磁盘
  • 内存

为了解决上述问题,专家们设计出更加利于管理数据的软件——数据库,它能更有效的管理数据。数据库可以提供远程服务,即通过远程连接来使用数据库,因此也称为数据库服务器

1.2数据库分类

数据库大体可以分为关系型数据库非关系型数据库

  • 关系型数据库(RDBMS):
    是指采用了关系模型来组织数据的数据库。简单来说,关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织。
    基于标准的SQL,只是内部一些实现有区别。常用的关系型数据库如:

    1. Oracle:甲骨文产品,适合大型项目,适用于做复杂的业务逻辑,如ERP、OA等企业信息系统。收费。
    2. MySQL:属于甲骨文,不适合做复杂的业务。开源免费。
    3. SQL Server:微软的产品,安装部署在windows server.上,适用于中大型项目。收费。
  • 非关系型数据库:
    (了解)不规定基于SQL实现。现在更多是指NoSQL数据库,如:

    1. 基于键值对(Key-Value):如memcached、redis

    2. 基于文档型:如mongodb

    3. 基于列族:如hbase

    4. 基于图型:如neo4j

    关系型数据库与非关系型数据库的 区别

    关系型数据库非关系型数据库
    使用SQL不强制要求,一般不基于SQL实现
    事务支持支持不支持
    复杂操作支持不支持
    海量读写操作效率低效率高
    基本结构基于表和列,结构固定灵活性比较高
    使用场景业务方面的OLTP系统用于数据的缓存、或基于统计分析的OLAP系统

02 SQL分类

  • DDL数据定义语言,用来维护存储数据的结构
    代表指令:create,drop,alter

  • DML数据操纵语言,用来对数据进行操作
    代表指令:insert,delete,update

    • DML中又单独分了一个DQL,数据查询语言,代表指令:select
  • DCL数据控制语言,主要负责权限管理和事务
    代表指令:grant,revoke,commit

03 数据库操作

MySQL是一个客户端,服务器结构的程序,MySQL的服务器是真正的本体,负责保存和管理数据,数据都是存储在硬盘上的。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-57hj5X5A-1691503192817)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808152444302.png)]

操作数据库的命令,也就是”SQL语句“,也可以理解为一种编程语言。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Hw5G5kyt-1691503192819)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808155232027.png)]

说明:操作数据库的时候,数据库对于字母的大小写不敏感,也就是说可以大写也可以小写。

3.1显示数据库

语法:show databases;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lxtvKB0w-1691503192819)(E:\Typora_note\MySQL\MySQL基础知识.assets\image-20230808164729682.png)]

3.2创建数据库

语法:create database 数据库名字;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BSihRQdz-1691503192820)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808165202056.png)]

  • 注意点就是,我们创建的数据库不能同名。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9nGedtWe-1691503192820)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808165438660.png)]

这里有解决方法:

就是在创建的时候加上修饰if not exists来解决问题。如图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OP1MyXJd-1691503192821)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808165727906.png)]

它也是可以适用于我们以后创建数据库保险一点的操作,因为在实际工作中,很多时候我们是将一系列的sql写到一个文件中,批量执行的,很少会一行一行去执行,那么在批量执行的情况下,要是其中有一条sql语句写错了,后续的失去了语句就无法继续执行了。


创建数据库的时候,可以手动指定一下字符集

语法:character set 字符集名字

亦或是:charset 字符集名字

  • 当我们创建数据库没有指定字符集和校检规则的话,系统会默认使用默认字符集:utf8,校检规则是:utf8_general_ci
  • 如果我们需要在数据库中保存中文,因为MySQL默认字符集是拉丁文,并不支持中文,所以我们必须在创建数据库的时候,手动将编码方式指定为支持中文的编码。(GBK、UTF8)
  • MySQL中的utf8其实是一个残本,不是完全体的utf8,少了一些复杂的中文,以及一些emoji表情,若想在MySQL中使用utf8的完全体,则我们需要输入utf8mb4.

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-E3hAoY4q-1691503192822)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808173403700.png)]

3.3选中数据库

语法:use 数据库名字;

数据库最重要的操作,就是针对表进行增删改查。表是属于数据库的,要针对表操作,就要先把哪个数据库的表这个事情搞清楚!

3.4删除数据库

语法:drop database 数据库名;

删除操作,删掉的不仅仅是database,而且也删除了database中的所有表,还有表里的所有数据。

那不然怎么经常有:从删库到跑路这句话呢~🐶🐶🐶

04 常用数据类型

MySQL中支持的数据类型。

一个表,包含很多行,每一行也称为一条记录。一个行里可以有很多列,每一列也称为是一个字段。每个列都是有一个具体类型的。

4.1数值类型

bit(m)m指定位数,默认1二进制数,m范围1-64,存储数值范围0-2^m-1常用boolean对应bit,此时默认是1位,即只能存0和1
tinyint1byte
smallint2short
int4integer
bigint8long
float(m,d)4单精度,m指定长度,d指定小数位数。会发生精度丢失float
double(m,d)8double
decimal(m,d)m/d最大值+2双精度,m指定长度,d指定小数位数。精确数值bigdecimal
numeric(m,d)m/d最大值+2双精度,m指定长度,d指定小数位数。精确数值bigdecimal

拓展:

  1. 数值类型可以指定为无符号(unsigned),表示不取负数。

  2. 1字节(bytes)= 8bit。

  3. 对于整型类型的范围:

    1. 有符号范围:-2(类型字节数*8-1)到2(类型字节数*8-1)-1,如int是4字节,就

      是-231到231-1

    2. 无符号范围:0到2(类型字节数*8)-1,如int就是232-1

  4. 尽量不使用unsigned,对于int类型可能存放不下的数据,int unsigned同样可能存放不下,与其

    如此,还不如设计时,将int类型提升为bigint类型。

在这里插入图片描述

4.2字符串类型

数据类型大小说明对应Java类型
varchar(size)0-65535字节可变长度字符串String
text0-65535字节长文本数据String
mediumtext0-16777215字节中等长度文本数据String
blob0-65535字节二进制形式的长文本数据byte[]

关于上表的一些小解读:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-78WiBUg7-1691503192823)(https://gitee.com/liuhb-clanguage/picture/raw/master/png/image-20230808215220387.png)]

4.3日期类型

数据类型大小说明对应Java类型
datetime8字节范围从1000到9999年,不会进行时区的检索及转换。java.util.Date、java.sql.Timestamp
timestamp4字节范围从1970到2038年,自动检索当前时区并进行转换。java.util.Date、java.sql.Timestamp

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

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

相关文章

LeetCode 0024. 两两交换链表中的节点:粗暴易懂的方法(几个临时变量)

【LetMeFly】24.两两交换链表中的节点:粗暴易懂的方法(几个临时变量) 力扣题目链接:https://leetcode.cn/problems/swap-nodes-in-pairs/ 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点…

安路FPGA的赋值报错——移位处理,加括号

authordaisy.skye的博客_CSDN博客-嵌入式,Qt,Linux领域博主 在使用移位符号用来当作除以号使用时,发现如下问题 其中 cnt_8K 为偶数和奇数时输出的数据不一样 reg [10:0] cnt_8K; reg [10:0] ram1_addra; always(posedge clk_16M) begin if(ram_out_flag )begin if(…

2023年新手如何学剪辑视频 想学视频剪辑如何入门

随着短视频、vlog等媒体形式的兴起,视频剪辑已经成为了热门技能。甚至有人说,不会修图可以,但不能不会剪视频。实际上,随着各种智能软件的发展,视频剪辑已经变得越来越简单。接下来,一起来看看新手如何学剪…

重磅来袭!Android UI设计规范助你打造精美Android应用!

重磅来袭!Android UI设计规范助你打造精美Android应用! 为了规范Android UI设计,Google官方推出UI设计指南助你打造精美的Android应用。 使用 Android 主题和组件创建应用设计。利用 Android 独特的设计模式和产品打造精美、易用的现代应用…

nginx之location匹配的规则和优先级,以及rewrite

主要内容:一、location匹配的规则和优先级(重点,面试会问,工作用得到) 二、nginx常用的问题(要求掌握) 三、rewrite:重定向功能(有掌握,有理解)…

DNS:使用 bind9 配置主从权威DNS服务器

写在前面 分享一些 使用 bind9 配置主从权威名称服务器的笔记理解不足小伙伴帮忙指正 对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。所有其它的路都是不完整的,是人的逃避方式…

设计模式行为型——策略模式

在现实生活中常常遇到达成某种目的,有多种实现策略可供选择的情况。例如,出行上班可以乘坐公交车、乘坐地铁、骑自行车或自己开私家车等,填饱肚子可以吃火锅、吃烤肉、吃烤串、吃东北家常菜等方法。 在软件开发中也常常遇到类似的情况&#x…

人物启示-张一鸣与陆奇

在科技行业中,张一鸣与陆奇可谓是两位颇具影响力的人物。张一鸣和陆奇分别是字节跳动(TikTok 的母公司)的创始人和百度前总裁。张一鸣作为字节跳动的创始人,成功打造了今日头条、抖音等知名产品,而陆奇则曾任微软副总裁…

计算机组成与设计01:计算机的抽象与技术

目录 1 概述 1.1 计算机体系结构体中的8个伟大思想 1.2 计算机层次结构 1.2.1 概述 1.2.2 指令集体系结构 1.3 实例:从程序到电子信号 1.3.1 从高级语言到汇编语言 1.3.2 从汇编语言到机器语言 1.3.3 生成可执行文件并执行 1.3.4 计算机基本执行结构 1.3…

【vue3】基础知识点-computed和watch

学习vue3,都会从基础知识点学起。了解setup函数,ref,recative,watch、computed、pinia等如何使用 今天说vue3组合式api,computed和watch 在vue3中,computed和watch仍然是非常有用的特性,帮助处…

【C语言】实现linux下基于C语言的一个简单的UDP客/服端通信

一、实例代码 对于基础好的朋友可以直接拿代码看 客户端代码&#xff1a; #include <stdio.h> #include <sys/socket.h>//socket() #include <netinet/in.h>//struct sockaddr_in #include <string.h>//memset() #include <arpa/inet.h>//ine…

数字化转型中的抉择:定制化软件还是引入PDM系统?

企业在数字化转型过程中可以考虑是使用定制化软件、基于成熟模块改造&#xff0c;或引入PDM&#xff08;产品数据管理&#xff09;系统&#xff0c;这时需要仔细权衡各种因素&#xff0c;以确保选择最适合其需求的路径。这些选择各自有其优势和适用场景&#xff0c;下面将分别对…

Linux项目部署

目录 一JAVAWeb环境的部署【安装JDK&#xff0c;MySQL数据库&#xff0c;Tomcat】 二.手工部署SpringBoot项目&#xff08;写的最好的&#xff09; 1.在IDEA中开发SpringBoot项目并打成jar包--点击右侧的Maven执行package命令 2.将jar包上传到Linux服务器 3.执行以下命令&a…

探究Spring事务:了解失效场景及应对策略

在现代软件开发中&#xff0c;数据的一致性和完整性是至关重要的。为了保证这些特性&#xff0c;Spring框架提供了强大的事务管理机制&#xff0c;让开发者能够更加自信地处理数据库操作。然而&#xff0c;事务并非银弹&#xff0c;存在一些失效的情景&#xff0c;本文将带您深…

C++ Visual Studio工程目录相对路径设置

文章目录 相对路径相对路径是相对vs工程的哪个目录而言书写格式 参考 相对路径 要设对相对路径&#xff0c;需要搞清楚下面两个问题&#xff1a; 相对路径是相对vs工程的哪个目录而言相对路径的书写格式 相对路径是相对vs工程的哪个目录而言 注意&#xff1a; 并非以解决方案…

LeetCode150道面试经典题-买卖股票的最佳时机(简单)

1、题目 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的…

麻了!包含中科院TOP,共16本期刊被标记为“On Hold”状态!

近日&#xff0c;小编从科睿唯安旗下的“Master Journal List”官网查到&#xff0c;除了知名老牌期刊Chemosphere竟然被标记为“On Hold”状态&#xff0c;目前共有7本SCI期刊&#xff0c;1本SSCI期刊&#xff0c;8本ESCI期刊被标记为“On Hold”&#xff0c;究竟是怎么回事呢…

一篇Android 真实面经(干货满满)

如梦朦胧 从年初开始就一直有换工作的躁动&#xff0c;因某些原因而拖到了现在,然后投了某度的Android岗位,本以为像我这种非211、985没工作经验的渣渣只能被直接pass,结果却意外的收到了电话,真是受宠若惊.经过电面,技术三面,然后就是等通知到最后拿到了OFFER,如梦一般,真是挺…

python小程序代码50 到100行,python小程序代码100行

这篇文章主要介绍了python小程序代码50 到100行&#xff0c;具有一定借鉴价值&#xff0c;需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获&#xff0c;下面让小编带着大家一起了解一下。 目录 1.生成漂亮的樱花树2.绝美的静态樱花树3.魔法少女小圆动漫形象4.利用pyth…

【注册表】windows系统注册表常用修改方案

文章目录 ◆ 修改IE浏览器打印页面参数设置◆气泡屏幕保护◆彩带屏幕保护程序◆过滤IP(适用于WIN2000)◆禁止显示IE的地址栏◆禁止更改&#xff29;&#xff25;默认的检查(winnt适用)◆允许DHCP(winnt适用)◆局域网自动断开的时间(winnt适用)◆禁止使用“重置WEB设置”◆禁止更…