`

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 '%11.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'  )  ;

 十一、多表关联更新与删除

 

  

#关联更新一个表的数据
update user a    join  user_ext b on a.uid=b.id  
set  b.name=a.name, b.age=a.age
where ifNULL(a.business_ip,'')<>ifNULL(b.new_business_ip,'')   
 
 #关联删除h表的数据
delete h.* 
from user  g   join user_ext h on g.id=h.userId
where g.id=1

in和exist的区别:
http://www.manongjc.com/article/981.html

 

 

 

 

分享到:
评论

相关推荐

    jmeter mysql 性能测试脚本

    自己整理的mysql性能测试脚本,需要的同学,可以下载使用

    Postgresql MySQL 性能测试TPCH-环境部署

    "Postgresql MySQL 性能测试TPCH-环境部署" TPCH(Transaction Processing Performance Council Benchmark H)是一种工业标准的基准测试工具,用于评估数据库管理系统的性能。TPCH-环境部署是指将TPCH基准测试工具...

    MySQL性能测试工具

    MySQLPT,可能是标题所指的特定性能测试工具,通常具备以下功能: 1. **模拟负载**:MySQLPT可以生成定制的SQL脚本,模拟不同类型的数据库操作,例如读写事务、简单查询或复杂的联接操作。这使得测试环境能够更准确...

    mysql性能测试工具

    mysql 性能测试工具sysbench 0.4.12.10版本

    mysql性能测试及分析

    【MySQL 性能测试与分析】 在IT领域,性能测试是评估系统能力的关键环节,尤其对于数据库管理系统(如MySQL)而言,确保其高效稳定运行至关重要。LoadRunner是一款强大的负载和性能测试工具,常用于测试应用程序的...

    MySQL 性能测试工具sysbench安装使用

    Sysbench是一款功能强大的数据库性能测试工具,通过它可以方便地评估不同配置下的数据库性能。通过本文介绍的方法,用户可以快速完成Sysbench的安装和配置,并执行基本的OLTP测试。对于需要深入评估数据库性能的应用...

    千万级Mysql-MongoDB性能对比报告

    #### MySQL性能测试结果分析 **用例1**: 对于单次提交10000条记录,每次提交1000次的情况,MySQL耗时3912秒完成操作。在此过程中,观察到CPU使用率提高了10%至20%,内存使用增加了0.5GB至1GB。值得注意的是,在没有...

    性能测试 mysql 耗时分析工具

    MySQL性能测试和耗时分析是数据库管理中的关键环节,它涉及到数据库优化、查询效率提升以及系统整体性能的改进。在本篇文章中,我们将深入探讨如何使用各种工具来对MySQL进行性能测试和耗时分析。 首先,我们要理解...

    MySQL官方测试数据库

    总之,"MySQL官方测试数据库"是一个全面的实践平台,涵盖了数据库设计、SQL查询、性能优化、安全管理和备份恢复等多个领域。无论你是初学者还是经验丰富的开发者,都可以从中受益,提升自己的MySQL技能。通过深入...

    MYSQL集群测试

    - mysqlslap是一个用于模拟多用户访问MySQL数据库的性能测试工具,它可以用来进行并发读写测试。 - sysbench是一个用于执行多线程的数据库和系统性能测试工具,它支持多种数据库,可以用来进行大数据量下的读写能力...

    loadrunner测试MySQL脚本

    LoadRunner是一款功能强大的性能测试工具,它可以帮助我们评估和优化应用程序在高负载下的表现,确保系统的稳定性和可靠性。在MySQL这样的关系型数据库中,性能测试尤为重要,因为它直接影响到数据的读写速度和系统...

    LoadRunner驱动MySQL性能测试(lib库实现)

    LoadRunner驱动MySQL性能测试(lib库实现)  前言  因为loadrunner原生未提供针对mysql测试的功能  国内网络上流传的都是ODBC连接mysql进行性能测试,过程较为繁琐  而LR本身推荐的是使用提供的dll库或者自行编写...

    [Mysql]性能测试脚本

    【MySQL 性能测试脚本】是用于评估和优化MySQL数据库性能的重要工具。在这个场景中,我们关注的脚本名为 `tuning-primer.sh`,它是一个自动化性能调优脚本,广泛应用于MySQL社区,帮助管理员检测数据库的性能瓶颈并...

    mysql数据库测试工程

    【MySQL数据库测试工程】 在IT领域,数据库是存储和管理数据的核心工具,而MySQL作为一款开源、免费的关系型数据库管理系统,被广泛应用于各种项目开发中。在这个“mysql数据库测试工程”中,我们将探讨如何结合...

    mysql压力测试工具

    - **数据库性能测试**:支持多种数据库引擎,包括MySQL,可以通过模拟多种操作(如INSERT、SELECT、UPDATE、DELETE)来测试数据库在高并发环境下的性能。 2. **sysbench安装** 对于Ubuntu系统,可以通过以下命令...

    mysql 测试数据集,单表200万条数据

    本测试数据集提供了一张包含200万条数据的单表,这对于数据库性能测试、查询优化、大数据处理以及系统负载测试等方面具有极高的价值。下面将围绕这个主题,详细介绍MySQL数据库的相关知识点。 1. 数据库设计: 在...

    MYSQL官方最新测试数据库 test_db.zip

    这个数据库可能包含了各种示例表、数据和预设的查询,以帮助开发者和管理员熟悉MySQL的功能和性能。 描述中提到的"最新版"指的是这个测试数据库与MySQL的当前稳定版本保持同步,包含了最新的特性和改进。这可能包括...

Global site tag (gtag.js) - Google Analytics