Linux基本数据库mysql了解

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

什么是关系型数据库
关系型数据库是依据关系模型来创建的数据库。
所谓关系模型就是“一对一、一对多、多对多”等关系模型,关系模型就是指二维表格模型,因而一个关系型数据库就是由二维表及其之间的联系组成的一个数据组织。
关系型数据可以很好地存储一些关系模型的数据,比如一个老师对应多个学生的数据(“多对多”),一本书对应多个作者(“一对多”),一本书对应一个出版日期(“一对一”)数据的存储形式:

什么是非关系型数据库(NOSQL)?
非关系型数据库主要是基于“非关系模型”的数据库(由于关系型太大,所以一般用“非关系型”来表示其他类型的数据库)
非关系型模型比如有:
存储的数据是一列列的。关系型数据库以一行作为一个记录,列模型数据库以一列为一个记录。(这种模型,IO很快,主要是一些分布式数据库)


关系型数据库与非关系型数据库的区别
1.关系型数据库:
优点:
1、易于维护:都是使用表结构,格式一致;
2、使用方便:SQL语言通用,可用于复杂查询;
3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询;
4、学习成本低。

缺点:
1、读写性能比较差,尤其是海量数据的高效率读写;
2、固定的表结构,灵活度稍欠;
3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。吞吐量
2.非关系型数据库
优点:
1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,文档形式、图片形式等等,使用灵活,应用场景广泛.
2、速度快:可以使用硬盘或者内存作为载体,而关系型数据库只能使用硬盘;redis数据库单线程10W
3、成本低:数据库部署简单,基本都是开源软件。

缺点:
1、不提供sql支持,学习和使用成本较高;
2、无事务处理;

系统数据库解析

information_schema:          虚拟库,主要存储了系统中的一些数据库对象的信息,例如用户表信息、列信息、权限信息、字符信息等

performance_schema:        主要存储数据库服务器的性能参数

mysql:                                  授权库,主要存储系统用户的权限信息

sys:                                         主要存储数据库服务器的性能参数(目标是把performance_schema的把复杂度降低)

数据库命名规则:

区分大小写

唯一性

不能使用关键字如 create SELECT

不能单独使用数字

不要使用中文

MyISAM和InnoDB的区别

MyISAM和InnoDB的区别

Mysql在V5.1之前默认存储引擎是MyISAM;在此之后默认存储引擎是InnoDB

MyISAM不支持事务,而InnoDB支持。InnoDB的AUTOCOMMIT默认是打开的,即每条SQL语句会默认被封装成一个事务,自动提交,这样会影响速度,所以最好是把多条SQL语句显示放在begin和commit之间,组成一个事务去提交。

InnoDB支持数据行锁定,MyISAM不支持行锁定,只支持锁定整个表。即 MyISAM同一个表上的读锁和写锁是互斥的,MyISAM并发读写时如果等待队列中既有读请求又有写请求,默认写请求的优先级高,即使读请求先到,所以 MyISAM不适合于有大量查询和修改并存的情况,那样查询进程会长时间阻塞。因为MyISAM是锁表,所以某项读操作比较耗时会使其他写进程饿死。

InnoDB支持外键,MyISAM不支持。

Innodb能存储64TB,MyISAM能存储256TB

InnoDB不支持全文索引,而MyISAM支持。全文索引是指对char、 varchar和text中的每个词(停用词除外)建立倒排序索引。MyISAM的全文索引其实没啥用,因为它不支持中文分词,必须由使用者分词后加入空格再写到数据表里,而且少于4个汉字的词会和停用词一样被忽略掉。(书的目录)

MyISAM支持GIS数据,InnoDB不支持。即MyISAM支持以下空间数据对象:Point,Line,Polygon,Surface等。
没有where的count(*)使用MyISAM要比InnoDB快得多。因为MyISAM内置了一个计数器,count(*)时它直接从计数器中读,而InnoDB必须扫描全表。

数据库的安全控制:

1、数据库不要暴露在公网

2、禁止root用户远程登录,授权一个普通账号。指定一个具体IP。

3、修改端口。

4、普通用户启动MySQL。

5、删除空口令账号。

6、开启二进制日志。

Mysql调优策略

1. 选择合适的存储引擎: InnoDB

2. 选取磁盘读写速度较快的设备作为Mysql服务器

3. 充分使用索引

4. 增加慢查询日志功能

5. 频繁访问的数据,用缓存数据库解决  redis

6. 单条查询最后增加 LIMIT 1,停止全表扫描

7. 设置最大连接数

8. 设置引擎的读写速度

NULL(null)说明:

1、等价于没有任何值、是未知数。

2、NULL与0、空字符串、空格都不同,NULL没有分配存储空间。

3、对空值做加、减、乘、除等运算操作,结果仍为空。

4、比较时使用关键字用“is null”和“is not null”。

5、排序时比其他数据都小,所以NULL值总是排在最前。

约束条件说明

NOT NULL                       标识该字段不能为null

UNIQUE KEY  (UK)         标识该字段的值是唯一的,可以为空,一个表中可以有多个

FOREIGN KEY (FK)         标识该字段为该表的外键,实现表与表(父表主键/子表1外键/子表2外键)之间的关联

PRIMARY KEY (PK)         标识该字段为该表的主键,可以唯一的标识记录,不可以为空

AUTO_INCREMENT         标识该字段的值自动增长(整数类型,而且为主键)

DEFAULT                          为该字段设置默认值

UNSIGNED                        无符号(正数)

ZEROFILL                         使用0填充,例如0000001

说明:
1. 是否允许为空,默认NULL;可设置NOT NULL,字段不允许为空,必须赋值

2. 字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值
    sex enum('male','female') not null default 'male'
    age int unsigned NOT NULL default 20        必须为正值(无符号) 不允许为空  默认是20

MySQL数据类型

数值类型

TINYINT: 1 字节,范围为 -128 到 127 或 0 到 255。

SMALLINT:2 字节,范围为 -32768 到 32767 或 0 到 65535。

MEDIUMINT:3 字节,范围为 -8388608 到 8388607 或 0 到 16777215。

INT:4 字节,范围为 -2147483648 到 2147483647 或 0 到 4294967295。

BIGINT:8 字节,范围为 -9223372036854775808 到 9223372036854775807 或 0 到 18446744073709551615。

FLOAT:4 字节,单精度浮点数,范围为 -3.402823466E+38 到 -1.175494351E-38,0,1.175494351E-38 到 3.402823466E+38。

DOUBLE:8 字节,双精度浮点数,范围为 -1.7976931348623157E+308 到 -2.2250738585072014E-308,0,2.2250738585072014E-308 到 1.7976931348623157E+308。

DECIMAL:变长的精确数值,支持 65 位整数位和 30 位小数位。

字符串类型

CHAR:定长字符串,最大长度为 255 个字符。

VARCHAR:变长字符串,最大长度为 65535 个字符。

BINARY:定长二进制字符串,最大长度为 255 个字节。

VARBINARY:变长二进制字符串,最大长度为 65535 个字节。空间会变小。

TEXT:变长字符串,最大长度为 65535 个字符。

BLOB:变长二进制字符串,最大长度为 65535 个字节。

ENUM:枚举类型,最多可以包含 65535 个值之一。

SET:集合类型,最多可以包含 64 个值之一。

日期/时间类型

DATE:日期,格式为 'YYYY-MM-DD'。

TIME:时间,格式为 'HH:MM:SS'。

DATETIME:日期和时间,格式为 'YYYY-MM-DD HH:MM:SS'。

TIMESTAMP:自动存储记录插入或更新的日期和时间,格式为 'YYYY-MM-DD HH:MM:SS'。

MySQL常见的数据类型

数值类型:
        整数类型 TINYINT(tinyint)SMALLINT(smallint) MEDIUMINT(mediumint) INT(int) BIGINT(bigint)   
        整型可以指定是有符号的和无符号的,默认是有符号的
       可以通过UNSIGNED(unsigned)来说明某个字段是无符号的。
       
        浮点数类型  FLOAT DOUBLE float double
            
字符串类型:
      CHAR系列    CHAR  VARCHAR
     BINARY系列  BINARY VARBINARY
     枚举类型:   ENUM
     集合类型:     SET  
       
时间和日期类型:   
     DATE TIME DATETIME TIMESTAMP YEAR

基本数据库sql

什么是sql

SQL代表结构化查询语言(Structured Query Language)。SQL是用于访问数据库的标准化语言。

SQL包含四个部分:

> - DDL 数据定义语言包含定义数据库及其对象的语句,例如表,视图,触发器,存储过程等。

> - DML 数据操作语言包含允许更新数据的语句。

> - DCL 数据控制语言允许授予用户权限访问数据库中特定数据的权限。

> - DQL 数据库查询语言

DDL定义语言

#查看数据库
mysql> show databases;

#查看创建的库信息
mysql> show create database 库名;

#查看当前库
mysql> select  database();             

#建库
mysql> create database 库名;
#建库时指定字符集
mysql> create database 库名 default charset 'utf8'

#切换数据库
mysql> use 库名;

#删除库
mysql> drop database 库名;

#建表
mysql> create table 表名(
        字段名1  类型[(宽度) 约束条件],
        字段名2  类型[(宽度) 约束条件],
        字段名3  类型[(宽度) 约束条件]
)[存储引擎 字符集];
==在同一张表中,字段名是不能相同
==宽度和约束条件可选
==字段名和类型是必须的

DML操作语言

#表中插入数据
mysql> insert into 表名 (字段名) values ("字段内容","字段内容")

#显示数据的详细信息
mysql> show table status like '表名' \G  


#修改表名称 修改字段名称  修改字段数据类型  修改字段的修饰符
mysql>alter tables 表名 change 原字段名 新字段名 需要修改的字段数据类型和修饰符
 #修改字段类型以及约束条件
  ​mysql>alter table 表名  modify 字段名  需要修改的字段数据类型和修饰符

#查看表
mysql> show tables;

#修改表名称
mysql> rename table 原名 to 新名;
mysql> alter table 原名 rename 新名;

#查询表结构
mysql> desc 表名;
mysql> show create table;

#删除表
mysql> drop table 库名;
 
#删除表中的数据
mysql> delete from  表名 where ;

#复制表
mysql> create table 新表名(select 可指定字段 from 原表名);

#更新数据
mysql> update 表名 set 字段1=值1,字段2=值2  WHERE CONDITION;

DCL控制语言

-- 授权
mysql> grant 需授权的权限 on *.* to '用户名'@'授权网段' identified by "密码";
mysql> flush privileges;

-- 回收权限
mysql> revoke 需要回收的权限 on *.* from '用户名'@'网段';

DQL查询语言

#查询表中指定字段的值
mysql> select 指定字段 from 表名;

#查询表中所有字段的值
mysql> select * from 表名;

- -查询字符小于某值
mysql> select * from 表名 字符<某值  # > = != <= >=

-- 查询一年值的总和并且重命名
mysql> select 字符*12 as 新名 from 表名

-- distinct避免重复 | 去重
mysql> select distinct 字符 from 表名

-- concat字符串的拼接
mysql> select CONCAT(字符,"连接语言",字符) FROM 表名

-- 查询某年的数据
mysql> select * from 表名 where 字符 like "某年%"
mysql> select * from 表名 where left(字符,4)=某年  -- right
mysql> select * from 表名 where 字符<"下年底" and 字符>"上年初"
mysql> select * from 表名 where 字符 between "下年底" and "上年初"
mysql> select * from 表名 where 字符 regexp="某年"   REGEXP-- 正则表达式

--集合
mysql> select * from 表名 where 字符  id=1 or id=3 or id=5
mysql> select * from 表名 where 字符  id in(1,3,5)

-- 排序 DESC降序 ASC 升序(默认)
mysql> select *  from 表名 order by 字符
mysql> select *  from 表名 order by 字符 desc

-- 分组
mysql> select 字符  from 表名 group by 字符

函数
   count()             统计数量
   max()               最大值
   min()               最小值
   avg()               平均值
   database()          当前所在库
   user()              当前登录用户
   now()               当前时间
   sum()               总和
   password()          指定密码

感谢观看!希望能够帮助到大家!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

06_树的入门

二叉树入门 树的基本定义树的相关术语二叉树的基本定义二叉查找树的创建二叉树的结点类二叉查找树API设计二叉查找树实现二叉查找树其他便捷方法查找二叉树中最小的键查找二叉树中最大的键 二叉树的基础遍历前序遍历中序遍历后序遍历 二叉树的层序遍历二叉树的最大深度问题折纸…

顺序结构复习

复习一些易错知识点还有习题 目录 可能不熟悉的知识点 逻辑表达式的求解 if,else的配队 条件运算符 运算符优先级的问题 switch的使用 goto和if构成的循环 例题讲解 1 2 3 4 ​编辑 5 ​编辑 6赋值 ​编辑 7 可能不熟悉的知识点 逻辑表达式的求解 如果…

redis基本用法学习(C#调用CSRedisCore操作redis)

除了NRedisStack包&#xff0c;csredis也是常用的redis操作模块&#xff08;从EasyCaching提供的常用redis操作包来看&#xff0c;CSRedis、freeredis、StackExchange.Redis应该都属于常用redis操作模块&#xff09;&#xff0c;本文学习使用C#调用CSRedis包操作redis的基本方式…

解决虚拟机卡顿、卡死、待机后不动的情况(真实有效

本人环境&#xff1a; VM workstation 17.5 ubuntu 22.04 虚拟机配置&#xff1a;4核 4g issue&#xff1a; 出现开机卡死不动运行一段时间&#xff0c;可能半小时不到&#xff0c;就页面卡死不动经常需要关机重启才解决&#xff0c;可能没有解决 1.配置虚拟化引擎 这一步我称…

在线客服系统:解决常见问题的实用工具与解决方案

市场得不断发展促使着消费者服务意识的觉醒&#xff0c;越来越多的消费者在购买产品的时候不仅看产品的功能、外观、性能&#xff0c;还关注品牌的服务质量。在线客服系统的出现帮助企业解决了客户服务难的问题。接下来&#xff0c;我们具体聊一聊在线客服系统能解决哪些问题&a…

Python办公自动化Day2-openpyxl

目录 文章声明⭐⭐⭐让我们开始今天的学习吧&#xff01;常规操作添加数据遍历所有单元格数据合并/取消合并单元格添加/删除行与列移动指定范围单元格 文章声明⭐⭐⭐ 该文章为我&#xff08;有编程语言基础&#xff0c;非编程小白&#xff09;的 Python办公自动化自学笔记知识…

2023年第6届传智杯省赛第二场复赛 解题报告 | 珂学家

前言 因为OJ的承办方是牛客&#xff0c;除了初赛用的原题有点争议外&#xff0c;复赛用的是原创的新题(点赞)。 说真的&#xff0c;这个难度&#xff0c;超过我的想象&#xff0c;打得非常的吃力。 我其实总共打了两场初赛&#xff0c;一场复赛&#xff0c;外加VP一场复赛&a…

如何用Excel制作一张能在网上浏览的动态数据报表

前言 如今各类BI产品大行其道&#xff0c;“数据可视化”成为一个热门词汇。相比价格高昂的各种BI软件&#xff0c;用Excel来制作动态报表就更加经济便捷。今天小编就将为大家介绍一下如何使用葡萄城公司的纯前端表格控件——SpreadJS来实现一个Excel动态报表&#xff1a; 实…

C语言中关于指针的理解

#include <stdio.h> int main() {int a11;int *p&a; //因为a是整型的&#xff0c;所以我们定义指针p的时候要和a的类型一样char b;char *pa&b; //同理&#xff0c;b是字符型&#xff0c;所以这里的pa也要用字符型return 0; }因为*p指向的是地址&…

高级RGA(二):父文档检索器

在我之前写的<<使用langchain与你自己的数据对话>>系列博客中&#xff0c;我们介绍了利用大型语言模型LLM来检索文档时的过程和步骤&#xff0c;如下图所示&#xff1a; 我们在检索文档之前&#xff0c;通常需要对文档进行切割&#xff0c;然后将其存入向量数据库如…

Seata源码——TCC模式总结

什么是TCC TCC 是分布式事务中的二阶段提交协议&#xff0c;它的全称为 Try-Confirm-Cancel&#xff0c;即资源预留&#xff08;Try&#xff09;、确认操作&#xff08;Confirm&#xff09;、取消操作&#xff08;Cancel&#xff09; TCC的步骤 1.Try&#xff1a;对业务资源…

米勒电容与米勒效应

米勒电容与米勒效应 米勒效应米勒效应的形成原理及分析米勒效应的危害和改进 米勒效应 Ciss CGE CGC 输入电容 Coss CGC CEC 输出电容 Crss CGC 米勒电容 下面我们以MOS中的米勒效应来展开说明&#xff1a; 米勒效应在MOS驱动中臭名昭著&#xff0c;它是由MOS管的米勒电容引发…

揭秘NCO:数字领域的音乐之旅

好的&#xff0c;让我们更详细地解析NCO的数学奥秘&#xff0c;深入探讨数字音乐的乐谱。在我们深入数学公式之前&#xff0c;让我们回顾一下&#xff0c;NCO就像是一位神奇的音符设计师&#xff0c;创造数字音乐的灵感源泉。 NCO&#xff1a;数字音符的魔法创造者 NCO&#x…

JavaEE:CAS详解

一.什么是CAS CAS: 全称 Compare and swap &#xff0c;字面意思 :” 比较并交换 “ &#xff0c;一个 CAS 涉及到以下操作&#xff1a; 我们假设内存中的原数据V&#xff0c;旧的预期值A&#xff0c;需要修改的新值B。 我们来进行操作&#xff1a; 1. 比较 V 和 A 是否相等。…

C语言中关于操作符的理解

本篇文章只会列出大家在生活中经常使用的操作符 算术操作符 在算数操作符中常用的有&#xff0c;&#xff0c;-&#xff0c;*&#xff0c;/&#xff0c;% &#xff0c;我们重点讲一讲 / (除) 和 % (模) " / "运算 #include <stdio.h>int main() {int a5/2;fl…

C/C++常见面试题(四)

C/C面试题集合四 目录 1、什么是C中的类&#xff1f;如何定义和实例化一个类&#xff1f; 2、请解释C中的继承和多态性。 3、什么是虚函数&#xff1f;为什么在基类中使用虚函数&#xff1f; 4、解释封装、继承和多态的概念&#xff0c;并提供相应的代码示例 5、如何处理内…

鸿蒙应用开发 常用组件与布局

简介 HarmonyOS ArkUI 提供了丰富多样的 UI 组件&#xff0c;您可以使用这些组件轻松地编写出更加丰富、漂亮的界面。在本篇 Codelab 中&#xff0c;您将通过一个简单的购物社交应用示例&#xff0c;学习如何使用常用的基础组件和容器组件。本示例主要包含&#xff1a;“登录”…

五、交换机基础配置实验

文章目录 实验内容实验拓扑配置交换机双工模式 实验内容 某公司刚成立&#xff0c;新组建网络&#xff0c;购置了 3 台交换机。其中 S1和 S2为接入层交换机&#xff0c;S3 为汇聚层交换机。现在网络管理员需要对3 台新交换机进行基本配置&#xff0c;保证交换机间的接口使用全…

Spring系列学习一、Spring框架的概论

Spring框架的概论 一、 Spring框架的起源与历史二、 Spring框架的核心理念与特点三、 Spring与其他框架的对比1、首先介绍下Spring与其平替的EJB的对比&#xff1a;2、接下来介绍下Spring与基于Java EE原生技术的对比3、Spring与Hibernate的对比4、Spring与Struts的对比 四、Sp…

Oracle研学-查询

学自B站黑马程序员 1.单表查询 //查询水表编号为 30408 的业主记录 select * from T_OWNERS where watermeter30408 //查询业主名称包含“刘”的业主记录 select * from t_owners where name like %刘% //查询业主名称包含“刘”的并且门牌号包含 5 的业主记录 select * from…