mysql命令行情况下的操作
一、变量的定义
第一种用法:set @num=1; 或set @num:=1; //这里要使用变量来保存数据,直接使用@num变量
第二种用法:select @num:=1; 或 select @num:=字段名 from 表名 where ……
如:
1)set @t_error=0; select @t_error ;
2)select @num:=`name` from sys_area where id=2 ; select @num;
二、启动事务和提交事务,回滚事务,如果打算启动事务则,设置自动提交为0,start transaction ; commit;
# 数值1自动提交 0手动提交
select @@autocommit;
#设置手动提交
set @@autocommit=0;
start transaction ;
insert into dic(name ) values('1');
insert into dic(name ) values('2');
ROLLBACK;
commit;
三、数据库的三大特性:原子性,一致性,隔离性,持久性
其中隔离性是不同事物之间的隔离原则,需要设置事务隔离级别来处理。
四、事务的隔离级别(针对有事务的业务的数据才会使用):
Read Uncommitted(读取未提交内容),Read Committed(读取提交内容),Repeatable Read(可重读),Serializable(可串行化)
1)查看当前会话隔离级别
select @@tx_isolation;
2)查看系统当前隔离级别
select @@global.tx_isolation;
3)设置当前会话隔离级别
set session transaction isolatin level repeatable read;
4)设置系统当前隔离级别
set global transaction isolation level repeatable read;
五、数据库的共享锁和排它锁
查询当前有多少事务,多少锁
SELECT * FROM information_schema.INNODB_TRX ;
SELECT * FROM information_schema.INNODB_LOCKS;
两者不同点在于是否允许另一个事务读取被锁住的数据
共享锁锁住了一条id=1的数据,则其他的事务是可以读取,但不能更改
排它锁锁住了一条id=1的数据,其他的事务不可以读取,也不能更改,直到这个事务完成
如果另一个查询没有显示添加锁,则他是可以读取数据,不受上面锁影响
例子:
select @@autocommit;
#设置手动提交
set @@autocommit=0;
set @t_error=0;
select @t_error ;
start transaction ;
select * from dic for update ;
insert into dic(name ) values('1');
insert into dic(name ) values('2');
ROLLBACK;
commit;
六、外键不能删除,必须先删除外键在删除相应的索引
#查看表的外键以及外键名称
show create table 表名
#删除外键
alter table 表名 drop FOREIGN KEY 外键名称 ;
#显示所有的索引,并且删除需要删除的索引
show index from 表名称 ;
alter table 表名称 drop index FK_cv98jak92idoqj8rrlyhkghv0 ;
七、字段的添加与删除
alter table 表名 drop column cluster_num
alter table 表名 add cluster_num int comment '数量';
八、NULL问题
SELECT 1 = NULL, 1 <> NULL, 1 < NULL, 1 > NULL;
九、show full processlist (状态字段的意思)
或者(select * from information_schema.processlist where host like '%10.168.2.65%')
1)Sleep
通常代表资源未释放,如果是通过连接池,sleep状态应该恒定在一定数量范围内
(一般连接池会有一个参数initialSize,如果initialSize=10则初始化的时候会有10个状态为sleep连接被建立,并且一直存在),
例如:
数据查询时间为0.1秒,而网络输出需要1秒左右,原本数据连接在0.1秒即可释放,但是因为前端程序未执行close操作,
直接输出结果,那么在结果未展现在用户桌面前,该数据库连接一直维持在sleep状态
2)Locked
操作被锁定,通常使用innodb可以很好的减少locked状态的产生
3)Copy to tmp table
索引及现有结构无法涵盖查询条件时,会建立一个临时表来满足查询要求,产生巨大的i/o压力Copy to tmp table通常与连表查询有关,
建议减少关联查询或者深入优化查询语句,如果出现此状态的语句执行时间过长,会严重影响其他操作,此时可以kill掉该操作
4)Sending data
Sending data并不是发送数据,是从物理磁盘获取数据的进程,如果你的影响结果集较多,那么就需要从不同的磁盘碎片去抽取数据,
如果sending data连接过多,通常是某查询的影响结果集过大,也就是查询的索引项不够优化
5)Storing result to query cache
如果频繁出现此状态,使用set profiling分析,如果存在资源开销在SQL整体开销的比例过大(即便是非常小的开销,看比例),
则说明query cache碎片较多,使用flush query cache可即时清理,Query cache参数可适当酌情设置
十、mysql日期时间函数的处理
date_format(date, format) 函数,MySQL日期格式化函数date_format()
unix_timestamp( 时间日期) 函数 ,Mysql日期转换为unix时间戳
str_to_date(str, format) 函数 ,字符串转化日期
from_unixtime(unix_timestamp, format) 函数,MySQL时间戳格式化函数from_unixtime
实例
select DATE_FORMAT(now(),'%Y-%m-%d' )
select str_to_date('2017-12-08 00:00:00', '%Y-%m-%d %H:%i:%s' )
select unix_timestamp( DATE_FORMAT(now(),'%Y-%m-%d' ) )*1000 ;
select unix_timestamp( str_to_date('2017-12-08 00:00:00', '%Y-%m-%d %H:%i:%s' ) )*1000 ;
select from_unixtime( unix_timestamp( DATE_FORMAT(now(),'%Y-%m-%d' ) ),'%Y-%m-%d %H:%i:%s' )
十一、in和exist区别
exist先查询主表,遍历主表每一条,然后在子查询中查询,如果有数据返回,则主表的这条数据放到返回的查询结果中,主要子表索引起作用。子表数据多了,但因为索引查询,速度比较快。
in:先查询子查询,得到查询结果,相当于查询结果or连接,然后使用主表索引,查询每个or条件的查询条件。那么子表查询结果集越多,最后查询越慢,子表越少查询越快
http://www.manongjc.com/article/981.html
相关推荐
总结,MySQL基础学习中涉及的主要知识点包括SQL语言的使用、数据库结构的设计、数据的导入导出、以及数据库的管理与维护。通过分析提供的文件,我们可以看到这涵盖了创建数据库、插入数据和管理数据的基本过程。实际...
Mysql基础学习资料Mysql基础学习资料Mysql基础学习资料Mysql基础学习资料
mysql 基础学习必学命令 mysql 是一个开源的关系型数据库管理系统,广泛应用于 web 应用程序中。在学习 mysql 之前,需要了解一些基本的命令和概念。本篇文章将为您介绍 mysql 的基本命令和知识点,以便您更好地...
这份"Mysql基础学习笔记"的压缩包很可能包含了关于MySQL基础知识的详细教程和实践指南。以下是一些可能涵盖的重要知识点: 1. **安装与配置**: - MySQL的安装过程,包括Windows、Linux和Mac OS等不同平台的安装...
总之,MySQL基础学习涉及数据库的基本概念、安装卸载流程、服务管理和SQL语句的使用。掌握这些基础知识是成为合格的MySQL用户的关键,对于日常的数据管理与分析工作至关重要。通过不断实践和深入学习,可以更熟练地...
### MySQL基础学习图文教程知识点概览 #### 一、MySQL环境配置 - **免安装版本配置**:本教程首先介绍了如何使用免安装版本的MySQL进行环境配置,这非常适合那些希望快速开始学习而无需复杂安装过程的新手用户。 ...
该教程为mysql基础学习教程,适合初入mysql的同学下载学习
基于Docker快速构建mysql基础学习环境
2. **MySQL基础** - **DBMS**:数据库管理系统(DataBase Management System),如MySQL,用于科学地组织和存储数据,高效地获取和维护数据。 - **SQL语句分类**:主要包括DDL(数据定义语言)、DML(数据操作语言...
MySQL安装启动,简单的数据库查询、表查询、以及表中数据的增删改。 适用于学习MySQL学习与记忆使用,
MySQL是全球广泛使用的开源关系型数据库管理系统,尤其在Web应用领域,它是最佳的RDBMS应用软件之一。本文将深入讲解MySQL的基础知识,包括其概述、...学习MySQL不仅可以提高工作效率,也是IT专业人士必备的技能之一。
MySQL概述 什么是数据库? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 、什么是 MySQL、Oracle、SQLite、Access、MS SQL Server等?
这是某某培训机构上课用的数据库基础学习指导资料,希望对各位有所帮助。
mysql入门学习第一讲,主要讲解数据库概述、数据库系统等。
这个是阿里集团的内部培训资料,有需求的朋友可以下来看看
自己写的用VS Code打开
首先,从标题我们可以推断,这份资料可能涵盖了MySQL的基础到进阶内容,包括安装配置、SQL语言基础、表设计、索引优化、事务处理、存储过程、触发器、视图、备份恢复、性能调优等多个方面。 描述中提到,这些资料是...
这份"MYSQL基础知识-学习笔记"涵盖了对MySQL的初步介绍以及基础概念,是初学者入门的理想资源。 首先,我们从MySQL的简介开始。MySQL是由瑞典的MySQL AB公司开发的,后被甲骨文公司收购。它是一款开源、免费的...