mysql5.5性能优化-内存表
临时表与内存表
内存表分为2种,但共同点是,重起数据库以后,内存中的数据全部丢失,内存表的功能有部分的限制,有些属性不能像正常表一样使用,所以请大家使用的时候谨慎参照官方文档.下面只是抛砖引玉.
1.临时表:表建在内存里,数据在内存里
2.内存表:表建在磁盘里,数据在内存里
其中包括2个重要的参数
[mysqld]
# 内存表容量
max_heap_table_size=1024M
# 临时表容量
tmp_table_size=1024M
建立内存表的时候,在5.5里,需要指定表的引擎类型 ENGINE=MEMORY
CREATE TABLE coldtest_vardata (
Id int(11) AUTO_INCREMENT,
name varchar(255)
) ENGINE=MEMORY DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT;
临时表
create temporary table tmp1(id int not null);
其他常用参数
# skip hostname,just use ip
skip-name-resolve
# auto start event
event_scheduler=1
2 . Mysql 5.5 无法远程登陆:Can't get hostname for your address
错误信息:Can't get hostname for your address
修改配置文件
在windows下面,文件时my.ini,在Linux下面是my.cnf
解决方案是在
[mysqld]
skip-name-resolve #加上这一个属性
它将禁止 MySQL Server 对外部连接进行 DNS 解析,使用这一选项可以消除 MySql 进行 DNS 解析的时间。
但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求。
可以这么理解mysql处理客户端解析的过程:
1,当 mysql client 发起连接请求时,MySql Server 会主动去查 client 的主机名。
2,首先查找Windows系统目录下 /etc/hosts 文件,搜索域名和IP的对应关系。
3,如果hosts文件没有,则查找DNS设置,如果没有设置DNS服务器,会立刻返回失败;如果设置了DNS服务器,就进行反向解析,直到timeout。
注意:如果开启 skip-name-resolve 选项,要确认 MySql 是否采用过主机名的授权,
在 mysql 中运行如下命令:
mysql> select user,host from mysql.user where host <> 'localhost' ;
一般会得到以“%”授权(也就是任何地址)的记录:
+------------------+-------------+
| user | host |
+------------------+-------------+
| root | % |
| user_sync | 192.168.0.113 |
如果有host名是什么“DB1”“DB2”的,那么删除授权表中有 hostanme 的记录,然后重启mysqld。
3。mysql JDBC 驱动常用的有两个,一个是gjt(Giant Java Tree)组织提供的mysql驱动,其JDBC Driver名称(JAVA类名)为:org.gjt.mm.mysql.Driver
详情请参见网站:http://www.gjt.org/另一个是mysql官方提供的JDBC Driver,其Java类名为:com.mysql.jdbc.Driver
驱动下载网址:http://dev.mysql.com/downloads/,进入其中的MySQL Connector/J区域下载。
mysql JDBC URL格式如下:
jdbc:mysql://[host:port]/[database][?参数名1][=参数值1][&参数名2][=参数值2]...
MySQL内存表相信大家都不会陌生,下面就对MySQL内存表heap使用进行了总结归纳,供您参考学习之用。
MySQL内存表使用哈希散列索引把数据保存在内存中,因此具有极快的速度,适合缓存中小型数据库,但是使用上受到一些限制。
1、heap对所有用户的连接是可见的,这使得它非常适合做缓存。
2、仅适合使用的场合。heap不允许使用xxxTEXT和xxxBLOB数据类型;只允许使用=和<=>操作符来搜索记录(不允许& lt;、>、<=或>=);不支持auto_increment;只允许对非空数据列进行索引(not null)。
注:操作符 “<=>” 说明:NULL-safe equal.这个操作符和“=”操作符执行相同的比较操作,不过在两个操作码均为NULL时,其所得值为1而不为NULL,而当一个操作码为NULL时,其所得值为0而不为NULL。
3、一旦服务器重启,所有heap表数据丢失,但是heap表结构仍然存在,因为heap表结构是存放在实际数据库路径下的,不会自动删除。重启之后,heap将被清空,这时候对heap的查询结果都是空的。
4、如果heap是复制的某数据表,则复制之后所有主键、索引、自增等格式将不复存在,需要重新添加主键和索引,如果需要的话。
5、对于重启造成的数据丢失,有以下的解决办法:
a、在任何查询之前,执行一次简单的查询,判断heap表是否存在数据,如果不存在,则把数据重新写入,或者DROP表重新复制某张表。这需要多做一次查询。不过可以写成include文件,在需要用该heap表的页面随时调用,比较方便。
b、对于需要该heap表的页面,在该页面第一次且仅在第一次查询该表时,对数据集结果进行判断,如果结果为空,则需要重新写入数据。这样可以节省一次查询。
c、更好的办法是在mysql每次重新启动时自动写入数据到heap,但是需要配置服务器,过程比较复杂,通用性受到限制。
蓝草目前采用的是第二种办法。
6、一些预期可能用到的sql语句
//如果表存在,则删除
DROP TABLE IF EXISTS `abc`;
//复制整张表xyz为heap表abc(包含所有数据)
CREATE TABLE `abc` type=heap select * from `xyz`;
//添加主键id
ALTER TABLE `abc` ADD PRIMARY KEY (`id`);
//添加索引username
ALTER TABLE `abc` ADD INDEX `abc` (`username`);
相关推荐
10. **内存管理优化**:改进了内存分配和管理,降低了内存碎片,提高了系统资源的使用效率。 安装`mysql-installer-community-5.6.43.0.msi`时,用户可以定制安装选项,选择需要的组件,如MySQL Server、MySQL ...
4. **增强的性能监控**:通过Performance Schema,用户可以更深入地了解数据库的运行情况,包括锁、线程、内存使用等,从而进行更有效的性能调优。 5. **柱状图索引(CTE)**:引入了Common Table Expressions(CTE...
- 使用`SQL_SMALL_RESULT`选项时,MySQL倾向于使用内存中的临时表。 - `DISTINCT`与`ORDER BY`结合使用时也可能需要临时表的支持。 2. **磁盘临时表的生成** - 如果查询中包含`BLOB`或`TEXT`类型的字段,那么...
本文将深入探讨MySQL临时表的使用方法、优势以及注意事项。 #### 创建临时表 创建临时表的基本语法非常简单,只需在`CREATE TABLE`语句前添加`TEMPORARY`关键字即可。例如: ```sql CREATE TEMPORARY TABLE tmp_...
下面将详细解释临时表的使用方法及其特点。 1. **临时表的创建与生命周期** 创建临时表的方式很简单,只需将常规的`CREATE TABLE`语句替换为`CREATE TEMPORARY TABLE`。例如: ```sql CREATE TEMPORARY TABLE ...
- **通用表表达式(CTE)**:提供了一种更清晰的方式来组织复杂的查询,可以临时创建一个虚拟表进行后续操作。 - **JSON增强**:支持更多的JSON操作,包括对JSON字段的索引,提高了处理JSON数据的效率。 - **行级...
- **通用表表达式(CTE)**:允许创建临时结果集,使得复杂的查询更易读和编写。 - **JSON支持**:提供了对JSON数据类型的内置支持,便于处理半结构化数据。 - **行级锁定改进**:减少了并发操作中的锁竞争,提高了多...
4. `DISTINCT`操作:如果没有被优化成`GROUP BY`或利用唯一索引消除,MySQL可能会使用内部临时表来处理`DISTINCT`。如:`SELECT DISTINCT a FROM t1`。 减少内部临时表的使用可以提高查询效率。编写更高效的SQL语句...
MySQL临时表是一种在数据库会话期间创建和使用的特殊类型的表,它们主要用于存储中间查询结果,以便在复杂的查询或处理大量数据时提高性能。临时表的名字只对当前会话可见,这意味着其他用户无法看到或访问你的临时...
### MySQL 临时表空间优化:提升数据库性能的关键 #### MySQL 特点概述 MySQL 是一个广泛使用的开源关系型数据库管理系统(RDBMS),基于 SQL 语言。它作为 LAMP 技术栈的一部分,在构建动态网站和 Web 应用程序...
MySQL临时表是数据库管理系统中的一种特殊表格,它主要用于在单个会话期间存储临时数据,以便在多个查询之间共享和处理。临时表的生命周期仅限于创建它的会话,一旦会话结束,临时表及其所有数据都会被自动删除,这...
- 了解MySQL如何自动创建临时表以及如何优化这些表的使用。 - 例如,使用内存临时表可以提高查询性能。 #### 五、InnoDB表优化 1. **InnoDB表存储布局优化** - 了解InnoDB如何组织数据可以提高查询性能。 - ...
MySQL中的临时表是数据库操作中的一种重要工具,用于在单个会话中存储临时数据,以便执行复杂的查询或处理。临时表分为两种类型:外部临时表和内部临时表。 外部临时表是通过`CREATE TEMPORARY TABLE`命令创建的,...
1. **存储引擎**:MySQL 5.0支持多种存储引擎,包括InnoDB(事务处理,支持行级锁定)、MyISAM(快速读取,不支持事务)和Memory(数据存储在内存中,适合临时表)等。InnoDB在5.0版本中进一步增强了事务处理能力,...
MySQL中的临时表是一种非常实用的数据存储机制,尤其在处理复杂查询和临时数据存储时。临时表主要用于在单个会话中存储数据,当会话结束时,这些表将自动删除,确保不会对数据库的长期状态产生影响。以下是关于MySQL...
7. **监控和调整**:定期监控数据库的资源使用情况,包括内存和临时表空间,以便及时发现和解决问题。 在实际应用中,需要根据具体数据库系统(如Oracle、MySQL、SQL Server等)的特点和配置进行针对性的调整。通过...
MySQL中的临时表是一种非常有用的工具,特别是在处理大量数据和复杂查询时,它可以显著提升查询效率。临时表在数据库会话的生命周期内存在,只对当前会话可见,且在会话结束时自动删除,这使得它们成为存储中间结果...
- **Day 10**: 探讨Employees数据库的结构,学习如何创建临时表以及设置外键约束。 - **Day 11**: 重点讲解SELECT语句的各种用法,包括基本查询、过滤条件等。 - **Day 12**: 深入研究子查询的应用场景,同时讲解...