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 中的关键字,数据库名以字母数字下划线随便起,但是不能和关键字重复,每个语句这里带有英文分号 ; 结尾)
alt

成功案例:

在这里插入图片描述

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

例子:

在这里插入图片描述

创建数据库的时候,还可以同时设置一个字符编码,对于数据库存储中文有一定的帮助

因为 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 数据库名;

在这里插入图片描述

删除数据库是一个非常危险的操作,一旦删掉之后,数据就没了.

如果你删除的是一个比较重要的生产环境的数据,就非常危险

工作中会接触到的几套环境:

  1. 办公环境: 发一个电脑 笔记本/台式机,进行日常办公使用的机器,配置比较低,用来通过通讯软件和其他同事交流,开一些会议,发邮件,写PPT等,配置像是 8c 16G 512G
  2. 开发环境: 写代码,编译代码,简单的运行代码,有些公司,开发环境就是办公环境(开发的项目比较简单),也有些公司,开发环境需要配专门的机器(服务器) 配置像是 28c 128G NT ,这样的服务器启动一下就要几十个GB的内存,在自己的电脑跑是不现实的
  3. 测试环境: 把写好的代码进行测试时候使用的环境,配置像是 28c 128G NT
  4. 生产环境: 办公,开发和测试环境统称为线下环境,生产环境也叫做线上环境,生产环境上面部署的程序,是可以直接被外面的用户访问到的,比如打开一个搜索引擎,在看到搜索结果的这个过程中访问了搜索引擎的生产环境的服务器,服务器经过运算返回结果.往往生产环境的配置是最高的,配置像是 56c 256G N T ,这样的机器可能还会有很多台.如果用户多了,对于机器的压力就比较大,每个用户进行一次访问,服务器都是需要消耗一定的硬件资源来进行计算的,包括但不限于cpu,内存,硬盘,网络宽带…如果同一时刻的用户访问量非常大,消耗的总资源超过了机器能够提供的资源上限,这个时候,服务器可能就挂了(网页刷不出来,甚至就卡死了…)这种情况就是高并发,为了应对高并发的情况,可以添加更多的机器解决,因此生产环境上所涉及到的甚至几百台服务器所构成了分布式系统(集群)

mysql中支持的数据类型

mysql是关系型数据库,是按照 数据表的方式来组织数据的,数据表中的每一列都会有具体的类型,下面说明一些比较重要的数据类型

1. 数值类型: NUMERIC(M,D)

float 和 double 不能精确保存,因此比较两个浮点数,不能使用 == ,而是需要通过作差, 小于一个误差值的形式(IEEE 754 标准)

在MySQL中,DECIMALNUMERIC 可以看作是相同的数据类型。事实上,这两者是可互换的,它们都用来存储精确的数值,这些数值有固定的小数位。这很重要,尤其是在处理财务数据时,比如货币,其中精度非常关键。

DECIMALNUMERIC类型允许用户定义精确度和小数位。格式可以表示为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 表名;

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何在OpenWRT安装内网穿透工具实现远程访问本地搭建的web网站界面

文章目录 前言1. 检查uhttpd安装2. 部署web站点3. 安装cpolar内网穿透4. 配置远程访问地址5. 配置固定远程地址 前言 uhttpd 是 OpenWrt/LuCI 开发者从零开始编写的 Web 服务器,目的是成为优秀稳定的、适合嵌入式设备的轻量级任务的 HTTP 服务器,并且和…

【Vue】本地使用 axios 调用第三方接口并处理跨域

前端处理跨域 一. 开发准备 开发工具:VScode框架:Vue2项目结构:vue脚手架生成的标准项目(以下仅显示主要部分) 本地已搭建好的端口:8080要请求的第三方接口:http://1.11.1.111:端口号/xxx-api…

大型语言模型的语义搜索(一):关键词搜索

关键词搜索(Keyword Search)是文本搜索种一种常用的技术,很多知名的应用app比如Spotify、YouTube 或 Google map等都会使用关键词搜索的算法来实现用户的搜索任务,关键词搜索是构建搜索系统最常用的方法,最常用的搜索算法是Okapi BM25&#x…

Unity基于AssetBundle资源管理流程详解

在Unity游戏开发中,资源管理是一个非常重要的环节。随着游戏的发展,资源会变得越来越庞大,因此需要一种高效的资源管理方式来减少内存占用和加快加载速度。AssetBundle是Unity提供的一种资源打包和加载方式,可以将资源打包成一个独…

JS前端高频面试

JS数据类型有哪些,区别是什么 js数据类型分为原始数据类型和引用数据类型。 原始数据类型包括:number,string,boolean,null,undefined,和es6新增的两种类型:bigint 和 symbol。&am…

使用 Coze 搭建 TiDB 助手

导读 本文介绍了使用 Coze 平台搭建 TiDB 文档助手的过程。通过比较不同 AI Bot 平台,突出了 Coze 在插件能力和易用性方面的优势。文章深入讨论了实现原理,包括知识库、function call、embedding 模型等关键概念,最后成功演示了如何在 Coze…

【EasyV】QGIS转换至EasyV

QGIS转换至EasyV 第一步:导入QGIS第二步 坐标系转换第三步 集合修正第四步 重命名字段第五步 导出WGS geojson坐标第六步 导入EasyV 第一步:导入QGIS 第二步 坐标系转换 第三步 集合修正 第四步 重命名字段 第五步 导出WGS geojson坐标 第六步 导入EasyV…

【Git】:初识git

初识git 一.创建git仓库二.管理文件三.认识.git内部结构 一.创建git仓库 1.安装git 使用yum install git -y即可安装git。 2.创建仓库 首先创建一个git目录。 3.初始化仓库 这里面有很多内容,后面会将,主要是用来进行追踪的。 4.配置name和email 当然也…

ClickHouse快速上手

简介 ClickHouse是一个用于联机分析(OLAP)的列式数据库管理系统(DBMS) 官网(https://clickhouse.com/docs/zh)给出的定义,其实没看懂 特性 ClickHouse支持一种基于SQL的声明式查询语言,它在许多情况下与ANSI SQL标准相同。使用时和MySQL有点相似&#…

Python输出函数有知道的吗?

print()函数主要用于在终端中输出程序结果。它接受可变参数,可输出多个数据,数据之间默认用空格隔开,输出完毕后默认以换行结尾。print()函数还接受sep和end参数来指定数据间隔和结尾符号,以及file参数来指定输出流。 1.print() 函…

一分钟学会MobaXterm当Linux客户端使用

一、介绍 MobaXterm是一款功能强大的远程计算机管理工具,它集成了各种网络工具和远程连接协议,可以帮助用户在Windows系统上轻松管理远程计算机。MobaXterm支持SSH、Telnet、RDP、VNC等多种远程连接协议,同时还集成了X11服务器,可…

爬虫在网页抓取的过程中可能会遇到哪些问题?

在网页抓取(爬虫)过程中,开发者可能会遇到多种问题,以下是一些常见问题及其解决方案: 1. IP封锁: 问题:封IP是最常见的问题,抓取的目标网站会识别并封锁频繁请求的IP地址。 解决方案…

【解决(几乎)任何机器学习问题】:处理分类变量篇(上篇)

这篇文章相当长,您可以添加至收藏夹,以便在后续有空时候悠闲地阅读。 本章因太长所以分为上下篇来上传,文章末尾有下篇链接 很多⼈在处理分类变量时都会遇到很多困难,因此这值得⽤整整⼀章的篇幅来讨论。在本章中,我将…

C++动态分配内存知识点!

个人主页:PingdiGuo_guo 收录专栏:C干货专栏 大家好呀,又是分享干货的时间,今天我们来学习一下动态分配内存。 文章目录 1.动态分配内存的思想 2.动态分配内存的概念 2.1内存分配函数 2.2动态内存的申请和释放 2.3内存碎片问…

MyBatis小技巧

MyBatis小技巧 一、#{}和${}1.#{}和${}的区别2.什么情况下必须使⽤${} 二、别名机制-typeAliases1.typeAlias2.package 三、mappers的配置1.mapper(1)resource(3)URL(3)class 2.package 四、插⼊数据时获取…

pikachu靶场-CSRF

CSRF: 介绍: Cross-site request forgery简称为"CSRF”。 在CSF的攻击场景中攻击者会伪造一个请求(这个请求一般是一个链接) 然后欺骗目标用户进行点击,用户一旦点击了这个请求,整个攻击也就完成了&#xff0…

泽攸科普——扫描电子显微镜(SEM)像衬度形成原理

扫描电镜通过电子束在样品表面进行周而复始的扫描运动,同时实时监测各种信号图像的产生,然后根据产生的信号多少来调制图像。 引起各种信号产生的扫描电镜图像衬度的来源有三个方面: 1. 试样本身性质:包括表面的凹凸不平、成分的…

把excel模版保存到文件夹里不走接口进行下载的方法

把excel保存到文件夹不走接口进行下载,一定要注意,需要放到public下的static文件夹下,如果没有static文件夹,就新建一个 !!!不放在static文件夹下可能会报错,提示:无法从…

尾矿库排洪系统结构仿真软件WKStruc(可试用)

1、背景介绍 尾矿库作为重大危险源之一,在国际灾害事故排名中位列第18位,根据中国钼业2019年8月刊《中国尾矿库溃坝与泄漏事故统计及成因分析》的统计,在46起尾矿库泄漏事故中,由于排洪设施导致的尾矿泄漏事故占比高达1/3&#x…

Mysql第二关之存储引擎

简介 所有关于Mysql数据库优化的介绍仿佛都有存储引擎的身影。本文介绍Mysql常用的有MyISAM存储引擎和Innodb存储引擎,还有常见的索引。 Mysql有两种常见的存储引擎,MyISAM和Innodb,它们各有优劣,经过多次优化和迭代,…