您的当前位置:首页正文

MySql基础总结(1)_MySQL

2023-11-21 来源:爱上美食网
对于MySql已经是第二次看了,这次主要的目的是将MySql系统的归纳一边,之前学MySql是将笔记写在本子上,以后不想总带着本子,所以再花点时间把笔记归纳在博客中。下午已将安装步骤详细的写了,现在归纳他的基本语法。至于语法很多都是满足Sql语法的,和Sql Server 、Oracle都差不多。符合“>”后的都是在dos中验证过的,并且复制后直接可以运行。

1.连接数据库:

>#在mysql中‘#’是注释符号,连接数据库时,输入账号和密码

>mysql -u root -p wwh

2.显示所有的数据库

>show databases;

3.切换,显示某个数据库

>use test;

4.显示对应数据库中的所有表:>show tables;

5.创建一个名称为user的数据库>create database user;6.创建一个使用utf8字符集的user数据库>create database if not exists user character set UTF8;>#如果不存在user,就创建,如果存在,则不创建user数据库7.创建一个使用utf8字符集,并带校对规则的user数据库>create database if not exists user character set UTF8 collate utf8_general_ci;

8.查看前面创建的user数据库的定义信息>show create database user;

9.删除前面创建的user数据库>drop database if exists user;

10.查看服务器中的数据库,并把其中user库的字符集修改为gbk>alter database user character set gbk;

11.修改、备份、恢复数据库数据(这应该算是MySql中特有的吧,不同的数据库备份恢复的指令不一样)备份:c:> mysqldump -u root -p wwh > d:user.sql 回车(可以无分号结束)密码回车注意:该SQL命令是MySQL特有的,必须是MySQL环境外执行,即Window中dos界面环境中执行,并未进入到MySql的服务器中。恢复:mysql:> source d:mydb2.sql;回车(需要分号结束)注意:该SQL命令是MySQL特有的,必须是MySQL环境中执行。

12. MySQL支持数据类型

注意:

(1)Date/Datetime/TimeStamp,定界符使用''或""(单引号和双引号),但部份数据库可能不支持"",优先推荐''作为定界符,对于日期类型, MySQL数据库有一个的判段-功能(2)varchar(变长)/char(定长)(3)Text(大于65536字符的数据)/Blob(存储二进制多媒体数据,例如Mp3等),该二类型都有四个子类型,根据存储内容的大小进行选择(4)INT型有带符号和无符号之分,int(5)表示int默认为5位,如果插入id值,小于5位,左补空格,如果插入id值,大于5位,按照插入值,但必须满足int类型的大小确定

(5)FLOAT(M,D),D表示小数点后的D位,按四舍五入计算,M表示除小数点外的所有位数总和

(6)tinyint/smallint/mediumint/int/bigint-1B/2B/3B/4B/8B

13.优化的方法:

以时间换空间或者以空间换时间。

14.注意:

在实际的开发中,可以考虑吧频繁用到的信息,优先考虑效率,存储到一张表中,把不常用的信息和比较占空间的信息,有限考虑空间占用,存储到辅表中。例如:QQ空间中的用户名和密码,还有日志和留言板的信息存储。

小编还为您整理了以下内容,可能对您也有帮助:

数据库基础知识——Mysql

数据库基础知识——Mysql包括什么是数据库、、主流数据库、MySQL架构、、服务器,数据库,表之间的关系、、使用数据库、、SQL分类、存储引擎。

1、什么是数据库

数据库是用来存储数据的。那么我们之前学习过的存储数据可以使用文件,那么为什么还要弄个数据库呢?

这就要谈谈用文件保存数据的几个缺点:

文件的安全性问题、文件不利于数据查询和管理、文件不利于存储海量数据、文件在程序中控制不方便。

因此为了解决上述的问题,专家们设计出更利于管理数据的东西——数据库,它更有效地管理数据。数据库的水平是衡量一个程序员水平的重要指标。

数据库:物理操作系统文件或其他形式文件类型的集合。在MySQL数据库中,数据库文件可

以是frm,MYD,MYI,ibd结尾的文件。当使用NDB引擎时,数据库的文件可能不是操作系统上的文件,而是存放在内存之中的文件,但是定义仍然不变。

2、主流数据库

l MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的SQL处理效果好。

l SQLSever:微软的产品,.Net程序元的最爱,常用于中大型项目。

l Oracle:甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。

2.1MySQL

我主要学习MySQL数据库,那么就再了解了解MySQL数据库。MySQL被设计为一个可移植的数据库,几乎在当前所有系统上都能运行,如:Linux,Windows,Mac,Solaris和FreeBSD。尽管各平台在底层(如线程)实现方面都各有不同。

但是MySQL基本上能保证在各个平台上的物理体系结构的一致性。因此,用户应该能够很好的理解MySQL数据库在所有这些平台上是如何运作的。

3、MySQL架构:

MySQL数据库由后台线程以及一个共享内存区组成。共享内存可以被运行的后台线程所共享。需要牢记的是,数据库实例才是真正用于操作数据库文件的。在MySQL中,实例与数据库的关系通常是一一对应的。即一个实例对应一个数据库,一个数据库对应一个实例。但是,在集群情况下可能存在一个数据库被多个数据实例使用的情况。

MySQL被设计为一个单进程多线程架构的数据库,这点与SQLServer比较类似,但与Oracle多进程的架构有所不同(Oracle的Windows版本也是单进程多线程架构的)。这也就是说,MySQL数据库实例在系统上的表示就是一个进程。可以通过ps指令观察MySQL数据库启动后的进程情况:

注意进程为17022的进程就是MySQL的实例。当启动实例时,MySQL数据库会去读取配置文件,根据配置文件中的参数来启动数据库实例。在MySQL数据库中可以没有配置文件,在这种情况下,MySQL会按照编译时的默认参数设置启动实例。

查看当MySQL实例启动时,会在那些位置查找配置文件:

[Lxy@VM-20-12-centos~]$mysql--help|grepmy.cnforderofpreference,my.cnf,$MYSQL_TCP_PORT,/etc/my.cnf/etc/mysql/my.cnf/usr/etc/my.cnf~/.my.cnf

可以看到,MySQL数据库是按照/etc/my.cnf->/etc/mysql/my.cnf->/usr/etc/my.cnf->~/.my.cnf的顺序来读取配置文件的。如果几个配置文件中都有同一个参数,MySQL数据库会按照读取到的最后一个参数为准。在Linux环境下,配置文件一般放在/etc/my.cnf下。在Windows平台下,配置文件的后缀名可能是.cnf或者.ini。

配置文件中有一个参数datadir,该参数指定了数据库所在的路径。在Linux操作系统下默认datadir为/usr/local/mysql/data,用户可以修改该参数,当然也可以使用该路径。

3.1连接服务器

输入:

mysql-uroot-p。

注意:

如果没有写-h127.0.0.1默认是本地连接

如果没有写``-P3306`默认是3306端口号

3.2服务器管理。

l 执行win+r输入services.msc打开服务管理器。

l 通过下图左侧停止,暂停,重启按钮进行服务管理(一般建议不要动)。

4、服务器,数据库,表之间的关系

所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库,一般开发人员针对每一个应用创建一个数据库。

为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据。

5、使用数据库

这里使用数据库只是一些简单的sql语句,更加相信更加复杂的将在后面的博客中逐渐呈现。

显示当前所有数据库。

showdatabases;

使用数据库。

use[数据库名];//例如use104_db;

创建数据库表。

createtablestudent(idint,namevarchar(20));

查看表信息。

desc[表名];//例如descstudent;

像指定表中插入数据。

insertinto[表名](id,name)values(1,"张三");//例如:insertintostudent(id,name)values(1,"张三");//也可以如果是全属性插入也可以省略属性字段//例如:insertintostudentvalues(2,"李四");//如果明确指定属性字段后面的插入字段必须与之匹配//例如:insertintostudent(id)values(3);

查询表中的数据。

清屏。

systemclear//mysql并没有提供清屏的指令可以使用系统自带的指令:

退出数据库。

6、SQL分类

l DDL【DataDefinitionlanguage】数据定义语言,用来维护存储数据的结构

代表指令:create,drop,alter。

l DML【DataManipulationLanguage】数据操纵语言,用来对数据进行操作的

代表指令:insert,delete,update。

l DML中又单独分了一个DQL,数据查询语言,代表指令:select。

l DCL【DataControlLanguage】数据控制语言,主要负责权限管理和事务

代表指令:grant,revoke,commit。

7、存储引擎

存储引擎:数据库管理系统如何存储数据,如何为存储的数据建立索引和如何更新,查询数据等技术的实现方法。MySQL的核心就是插件式存储引擎,支持多种存储引擎。

Mysql基础知识点《一》

查询缓存中的好吗?是不是要开启查询缓存呢?其实不建议开启查询缓存,原因是缓存失效非常频繁,只要表更新了,缓存就会失效。所以对于那些更新操作多的表来说简直是灾难,除非是静态表,所以在mysql8中已经将查询缓存取消了。

这是因为sql操作涉及的表不一定只有sql语句中的那些,要在执行器阶段才能确认。

如果表 T 中没有字段 k,而你执行了这个语句 select * from T
where k=1, 那肯定是会报“不存在这个列”的错误: “Unknown column ‘k’ in
‘where clause’”。你觉得这个错误是在我们上面提到的哪个阶段报出来的呢?

:分析器阶段,在分析器阶段解析器会解析sql语句生成一颗解析树,判断表时候存在,列字段是否存在等。

Mysql基础知识点《一》

查询缓存中的好吗?是不是要开启查询缓存呢?其实不建议开启查询缓存,原因是缓存失效非常频繁,只要表更新了,缓存就会失效。所以对于那些更新操作多的表来说简直是灾难,除非是静态表,所以在mysql8中已经将查询缓存取消了。

这是因为sql操作涉及的表不一定只有sql语句中的那些,要在执行器阶段才能确认。

如果表 T 中没有字段 k,而你执行了这个语句 select * from T
where k=1, 那肯定是会报“不存在这个列”的错误: “Unknown column ‘k’ in
‘where clause’”。你觉得这个错误是在我们上面提到的哪个阶段报出来的呢?

:分析器阶段,在分析器阶段解析器会解析sql语句生成一颗解析树,判断表时候存在,列字段是否存在等。

MySQL笔记1select基础

查询语句:select 语句

三种能力:投影、选择、连接

投影:在一张二维表中根据所需要的条件选出所需要的列

选择:在二维表中根据所需的条件选择合适的行

连接:从一张或者多张表中获取所需要的行,并且把这个行结合在一起的查询

SQL语句大小写不敏感。

select语句是可以计算的

算术表达式和运算符优先级

举例:select ename,sal 12*sal+100 from emp

计算出年薪+100块

NULL值是不可用,且未分配的,未知并且不适用的值,可以当成是保留值

AS其实可以省略

例如:select ename as name,sal salary from emp;

查询出的字段会自动换成别名

例子:select ename "Name",sal*12 "Annual Salary" from emp;

级联操作是将列或字符串和其他列串联,由两条竖线(||)表示

select ename,job,ename || job as "Employees" from emp;

可以看出Employees就将ENAME和JOB进行结合的一个操作

在select句子中适用DISTINCT 关键字消除重复行

select distinct deptnp from emp;

选择的行:

where关键字

如果where后面查的数据是字符串类型或者日期类型的要加''号

#######比较条件

举几个例子:

select ename,job,sal,deptno from emp where sal between 5000 and 10000;

这个是包含了5000和10000的

in的表达:

select empno,ename,mgr,deptno from emp where mgr in (7788,7782,7000);

只要mgr有括号里面的值都显示出来。

通配符:%通配的是多个字符,_通配的是一个字符

IS NULL是查询某个字段为空的显示出来

and、or、not

例子:

查询sal>=2000和job的内容是包括MAN字符串的,当同时满足两个条件时候才返回结果。

and就是两边同时为真,or的话是有一边为真就行,not就是不等于

ASC 升序,默认升序

DESC 降序

例子:

将deptno中进行升序排列,排列出来后,在将sal进行降序排列。

单行函数:就是对单行数据进行处理的函数,只针对这一条数据得出一个结果

函数工作的过程

ROUND(45.926,2)是将45.926这个数字的小数点后两位进行四舍五入操作得到45.93

TRUNC(45.926,2) 是将45.926这个数字的小数点后两位后面的进行丢掉。

返回当前系统日期

经常是不同类型之间的转换

TO_CHAR就是将日期型数字型转换成字符型

例子:

数字型的转换

把字符转换成数字:

把字符转换成日期:

什么是分组函数?

另外的名字叫多行函数,针对于多行数据进行一个汇总处理的一类函数,最后会得到一个汇总的结果。

例子:

其实就是对一系列数据找最大值

基本格式:select group_function(column),... from table [where condition];

首先对一个数据进行分类汇总把每一组的数据单独的拿出来。就是对每一列数据的相同数据进行一个分组,然后在将分组后的结果再去执行select后面跟的一个分组函数的操作。

例子:

那下面这样的怎么操作呢?

其实就是对分组以后的结果再次进行一个筛选

where和Having的区别?

where是针对于整体的一个查询结果

Having是针对于分组后的查询结果的一个条件,它是不能单独存在的,它只能够在group by后面

下面是它的表达式:

显示部门的最大平均薪水是多少

select max(avg(sal))

是这样的一个嵌套

当我们查的数据存在于多个表的时候就需要多表查询

下面是用到的表

一个是EMP的职员表、一个是DEPT的部分表

表连接的三种方式:

从总类上来看:自连接、等值连接、外连接(又可以分为三类:左连接、右连接、全连接)

自连接:一个表自己与自己建立连接成为自连接或自身连接。

在查询的时候多表,这两张表是同一张表,所以在查询前我们需要对这个表进行一个别名的重命名。

举例:查询出员工编号、名字及其经理名字

MGR对应的是经理的ID号,这个对应的就是另一张经理表中的名字

表示比较连接列的值显示出最终的一个结果,其查询结果中列出被连接表中的所有列,包括其中的重复列。

查询员工的姓名 工作 部门号 部门名称

左连接就是返回左边的匹配行,不考虑右边的表是否有相应的行

(+)的意思就是dept是个匹配表,左边是一个基础表,基础表优先,如果右边这个表找不到对应的值去匹配,会自动填空

右连接就是返回右边的匹配行,不考虑左边的表是否有相应的行,如果没有会自动填空

左表右表都不做,所有的记录都显示,不足的地方用null填充

FULL JOIN表示emp和dept做一个全连接

ON表示触发条件 。

MYSQL使用基础、进阶分享

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,属于Oracle旗下产品,是最流行的关系型数据库管理系统之一。

端口是3306。

表很多时,使用linux脚本,需要根据需要修改一下:

和创建一样,可以加上 if exists

可两篇文章:

如:

用于在已有的表中添加、删除或修改列。

添加 ADD

默认是添加到最后,但可以指定位置。 FIRST :添加最前

AFTER 字段名> :添加指定字段之后

例子:

删除 DROP

修改 MODIFY 主要修改原列的类型或约束条件 同样可以用 FIRST 和 AFTER 字段名> ,代表的是修改到哪里。

修改字段名 CHANGE

可以把表2的数据复制到表1中,但 不能复制约束性条件 。

单行

多行,注意 只有一个VALUES :

不写 (行1, 行2...) 这一部分的话,默认一一对应

除了以上方法外,还可以用SET为每一行附上相应的值。

假如没有筛选的话,就给全部都修改了。可以用 WHERE 筛选。

假如 没有筛选的话,就给全部删除了 。相当于清空。

清空

先把表删除,然后再建一个。与 DELETE FROM 相比, TRUNCATE 的效率更快,因为 DELETE FROM 是把记录逐条删除的。

查询执行的顺序

FROM - WHERE - SELECT - GROUP BY - HAVING - ORDER BY - LIMIT

注意

当数据很大,上百万的时候,使用LIMIT ... OFFSET ..的方式进行分页十分浪费资源且耗时长。最好是结合WHERE使用,如:

REGEXP 使用正则表达进行匹配。 查询时,需要搭配WHERE或HAVING使用 。

两个表之间有交集且要用到两个表的数据时,可以使用内连接查询。

LEFT JOIN 关键字从左表(table1)返回所有的行,即使右表(table2)中没有匹配。如果右表中没有匹配,则结果为 NULL。

用法:

RIGHT JOIN 关键字从右表(table2)返回所有的行,即使左表(table1)中没有匹配。如果左表中没有匹配,则结果为 NULL。 把LEFT JOIN的表1、表2调换顺序,就是REGHT JOIN 。

FULL OUTER JOIN 关键字只要左表(table1)和右表(table2)其中一个表中存在匹配,则返回行. 相当于结合了 LEFT JOIN 和 RIGHT JOIN 的结果。

但 MySQL中不支持 FULL OUTER JOIN 。

即SELECT嵌套。

IN 一个查询结果作为另一个查询的条件。 如:

EXISTS 用于判断查询子句是否有记录,如果有一条或多条记录存在返回 True,否则返回 False。True时执行。 如:

索引的本质是一种排好序的数据结构。利用索引可以提高查询速度。

常见的索引有:

MySQL通过外键约束来保证表与表之间的数据的完整性和准确性。 外键的使用条件:

外键的好处:可以使得两张表关联,保证数据的一致性和实现一些级联操作。

对已有的两个表增加外键 比如:主表为A,子表为B,外键为aid,外键约束名字为a_fk_b

为子表添加一个字段,当做外键

为子表添加外键约束条件

假如删除记录报错: [Err] 1451 -Cannot deleteorupdatea parent row: aforeignkeyconstraintfails (...)

这是因为MySQL中设置了foreign key关联,造成无法更新或删除数据。可以通过设置 FOREIGN_KEY_CHECKS 变量来避免这种情况。 第一步:禁用外键约束,我们可以使用: SETFOREIGN_KEY_CHECKS=0; 第二步:删除数据 第三步:启动外键约束,我们可以使用: SETFOREIGN_KEY_CHECKS=1; 查看当前FOREIGN_KEY_CHECKS的值,可用如下命令: SELECT @@FOREIGN_KEY_CHECKS;

使用 UNION 来组合两个查询,如果第一个查询返回 M 行,第二个查询返回 N 行,那么组合查询的结果一般为 M+N 行。

每个查询必须包含相同的列、表达式和聚集函数。

默认会去除相同行,如果需要 保留 相同行,使用 UNION ALL 。

只能包含一个 ORDER BY 子句,并且必须位于语句的最后 。

内置函数很多, 见: MySQL 函数

我们一般使用 START TRANSACTION 或 BEGIN 开启事务, COMMIT 提交事务中的命令, SAVEPOINT : 相当于设置一个还原点, ROLLBACK TO : 回滚到某个还原点下

一般的使用格式如下:

开启事务时, 默认加锁

根据类型可分为共享锁(SHARED LOCK)和排他锁(EXCLUSIVE LOCK)或者叫读锁(READ LOCK)和写锁(WRITE LOCK)。

根据粒度划分又分表锁和行锁。表锁由数据库服务器实现,行锁由存储引擎实现。

除此之外,我们可以显示加锁

加锁时, 如果没有索引,会锁表,如果加了索引,就会锁行

InnoDB默认支持行锁,获取锁是分步的,并不是一次性获取所有的锁,因此在锁竞争的时候就会出现死锁的情况

解决方法:

即ACID特性:

由于并发事务会引发上面这些问题, 我们可以设置事务的隔离级别解决上面的问题.

MySQL的默认隔离级别(可重复读)

查看当前会话隔离级别

方式1

方式2

设置隔离级别

主从集群的示意图如下:

主要涉及三个线程: binlog 线程、 I/O 线程和 SQL 线程。

同步流程:

由于MySQL主从集群只会从主节点同步到从节点, 不会反过来同步, 所以需要读写分离

读写分离需要在业务层面实现 , 写数据只能在主节点上完成, 而读数据可以在主节点或从节点上完成

索引是帮助MySQL高效获取数据的排好序的数据结构

MySQL的索引有

推荐两个在线工具:

简单来说, B树是在红黑树(一个平衡二叉树)的基础上将一个节点存放多个值, 实现的, 降低了树的高度, 每个节点都存放索引及对应数据指针, 同一层的节点是递增的

而B+树在B树的基础上进行优化, 非叶子节点存放 子节点的开始的索引, 叶子节点存放索引和数据的指针, 且叶子节点之间有双向的指针

如下示意图:

不同的引擎, 主键索引存放的数据也不一样, 比如常见的 MyISAM 和 InnoDB

MyISAM 的B+树叶子节点存放表数据的指针, InnoDB 的B+树叶子节点存放处主键外的数据

其他的:

即多个列组成一个索引, 语法:

由于联合索引的B+树的结构, 根据列建立, 所以我们的查找条件也要根据索引列的顺序( where column1=x, column2=y,columnN... ), 否则会全表扫描

如果你对列进行了 (+,-,*,/,!) , 那么都将不会走索引。

OR 引起的索引失效

OR 导致索引是在特定情况下的,并不是所有的 OR 都是使索引失效,如果OR连接的是 同 一个字段,那么索引 不会失效 , 反之索引失效 。

这个我相信大家都明白,模糊搜索如果你前缀也进行模糊搜索,那么不会走索引。

这两种用法,也将使索引失效。另 IN 会走索引,但是当IN的取值范围较大时会导致索引失效,走全表扫描, 见: MySQL中使用IN会不会走索引

不走索引。

走索引。

所以设计表的时候, 建议不可为空, 而是将默认值设置为 "" ( NOT NULL DEFAULT "" )

本文如未解决您的问题请添加抖音号:51dongshi(抖音搜索懂视),直接咨询即可。

上一篇:新鲜草莓的保存方法

下一篇:

热门图文

  • jswindow.event对象详尽解析_javascript技巧

    JS的event对象Event属性和方法:1. type:事件的类型,如onlick中的click;2. srcElement/target:事件源,就是发生事件的元素;3. button:声明被按下的鼠标键,整数,1代表左键,2代表右键,4代表中键,如果按下多个键,酒把这些值加起来,所以3就代表左右键同时按下;(firefox中 0代表左键,1代表中间键,2代表右键)4. clientX/clientY:事件发生的时候,鼠标相对于浏览器窗口可视文档区域的左上角的位置;(在DOM标准中,这两个属

  • 检测是否已安装.NETFramework3.5的js脚本_javascript技巧

    本主题提供一个以 HTML/JavaScript 编写的脚本,管理员可以使用该脚本来确定系统上是否存在 .NET Framework 3.5。<HTML<HEAD<TITLETest for the .NET Framework 3.5</TITLE<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=utf-8" /<SCRIPT LANGUAGE=&q

  • javascriptTable中2个列(TD)的交换实现代码_javascript技巧

      很简单的,给你个思路:例如A、B表格一行只有一个单元格,那么给A表格要移动内容的行TD,定义一个ID1;给B表格要存放内容的那行TD,定义一个ID2。然后JS中通过ID1获取A表格那行TD内容,再在JS中通过ID2赋值内容。涉及语法://获取A表格那单元格内容var tableATdValue = document.getElementById("ID1").innerHTML;//内容存入B表格那单元格document.getElementById("ID2&

  • javascript模拟select下拉列表特效_表单特效

    <script language="javascript">function i(vl){ if(vl==6){ document.getElementById("div1").innerHTML="<input type='text' value='' name='t1' id='t1'>"; }else{ document.getElemen

  • js静态HTML表格排序功能实现_javascript技巧

    页面中如下格式的人员信息表格:表格每行的HTML结构为:<tr> <td><input type="checkbox"></td> <td>2</td> <td>李斯</td> <td>43</td> <td>陕西</td></tr>假定表格的元素id为person-list,奇数行的class名为odd。 请实现如下功能

Top