`

MySQL的经典用法----临时表与内存表

阅读更多

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`);

分享到:
评论

相关推荐

    mysql-installer-community-5.6.43.0.msi

    10. **内存管理优化**:改进了内存分配和管理,降低了内存碎片,提高了系统资源的使用效率。 安装`mysql-installer-community-5.6.43.0.msi`时,用户可以定制安装选项,选择需要的组件,如MySQL Server、MySQL ...

    mysql-server-mysql-5.7.36.tar.gz

    4. **增强的性能监控**:通过Performance Schema,用户可以更深入地了解数据库的运行情况,包括锁、线程、内存使用等,从而进行更有效的性能调优。 5. **柱状图索引(CTE)**:引入了Common Table Expressions(CTE...

    MySQL性能分析之临时表

    - 使用`SQL_SMALL_RESULT`选项时,MySQL倾向于使用内存中的临时表。 - `DISTINCT`与`ORDER BY`结合使用时也可能需要临时表的支持。 2. **磁盘临时表的生成** - 如果查询中包含`BLOB`或`TEXT`类型的字段,那么...

    Mysql临时表使用说明

    本文将深入探讨MySQL临时表的使用方法、优势以及注意事项。 #### 创建临时表 创建临时表的基本语法非常简单,只需在`CREATE TABLE`语句前添加`TEMPORARY`关键字即可。例如: ```sql CREATE TEMPORARY TABLE tmp_...

    MYSQL 临时表用法总结

    下面将详细解释临时表的使用方法及其特点。 1. **临时表的创建与生命周期** 创建临时表的方式很简单,只需将常规的`CREATE TABLE`语句替换为`CREATE TEMPORARY TABLE`。例如: ```sql CREATE TEMPORARY TABLE ...

    mysql-8.0.17-winx64.zip

    - **通用表表达式(CTE)**:提供了一种更清晰的方式来组织复杂的查询,可以临时创建一个虚拟表进行后续操作。 - **JSON增强**:支持更多的JSON操作,包括对JSON字段的索引,提高了处理JSON数据的效率。 - **行级...

    mysql-8-winx64.zip

    - **通用表表达式(CTE)**:允许创建临时结果集,使得复杂的查询更易读和编写。 - **JSON支持**:提供了对JSON数据类型的内置支持,便于处理半结构化数据。 - **行级锁定改进**:减少了并发操作中的锁竞争,提高了多...

    MySQL中的两种临时表

    4. `DISTINCT`操作:如果没有被优化成`GROUP BY`或利用唯一索引消除,MySQL可能会使用内部临时表来处理`DISTINCT`。如:`SELECT DISTINCT a FROM t1`。 减少内部临时表的使用可以提高查询效率。编写更高效的SQL语句...

    MySQL临时表的简单用法介绍

    MySQL临时表是一种在数据库会话期间创建和使用的特殊类型的表,它们主要用于存储中间查询结果,以便在复杂的查询或处理大量数据时提高性能。临时表的名字只对当前会话可见,这意味着其他用户无法看到或访问你的临时...

    MySQL临时表空间优化:提升数据库性能的关键

    ### MySQL 临时表空间优化:提升数据库性能的关键 #### MySQL 特点概述 MySQL 是一个广泛使用的开源关系型数据库管理系统(RDBMS),基于 SQL 语言。它作为 LAMP 技术栈的一部分,在构建动态网站和 Web 应用程序...

    Mysql临时表原理及创建方法解析

    MySQL临时表是数据库管理系统中的一种特殊表格,它主要用于在单个会话期间存储临时数据,以便在多个查询之间共享和处理。临时表的生命周期仅限于创建它的会话,一旦会话结束,临时表及其所有数据都会被自动删除,这...

    MySQL5.7-optmization

    - 了解MySQL如何自动创建临时表以及如何优化这些表的使用。 - 例如,使用内存临时表可以提高查询性能。 #### 五、InnoDB表优化 1. **InnoDB表存储布局优化** - 了解InnoDB如何组织数据可以提高查询性能。 - ...

    MySQL两种临时表的用法详解

    MySQL中的临时表是数据库操作中的一种重要工具,用于在单个会话中存储临时数据,以便执行复杂的查询或处理。临时表分为两种类型:外部临时表和内部临时表。 外部临时表是通过`CREATE TEMPORARY TABLE`命令创建的,...

    mysql-essential-5.0.87

    1. **存储引擎**:MySQL 5.0支持多种存储引擎,包括InnoDB(事务处理,支持行级锁定)、MyISAM(快速读取,不支持事务)和Memory(数据存储在内存中,适合临时表)等。InnoDB在5.0版本中进一步增强了事务处理能力,...

    MySQL中关于临时表的一些基本使用方法

    MySQL中的临时表是一种非常实用的数据存储机制,尤其在处理复杂查询和临时数据存储时。临时表主要用于在单个会话中存储数据,当会话结束时,这些表将自动删除,确保不会对数据库的长期状态产生影响。以下是关于MySQL...

    转--一次HASH JOIN 临时表空间不足的分析和优化思路

    7. **监控和调整**:定期监控数据库的资源使用情况,包括内存和临时表空间,以便及时发现和解决问题。 在实际应用中,需要根据具体数据库系统(如Oracle、MySQL、SQL Server等)的特点和配置进行针对性的调整。通过...

    MySQL使用临时表加速查询的方法

    MySQL中的临时表是一种非常有用的工具,特别是在处理大量数据和复杂查询时,它可以显著提升查询效率。临时表在数据库会话的生命周期内存在,只对当前会话可见,且在会话结束时自动删除,这使得它们成为存储中间结果...

    MySQL网络培训精品班-Inside君姜承尧

    - **Day 10**: 探讨Employees数据库的结构,学习如何创建临时表以及设置外键约束。 - **Day 11**: 重点讲解SELECT语句的各种用法,包括基本查询、过滤条件等。 - **Day 12**: 深入研究子查询的应用场景,同时讲解...

Global site tag (gtag.js) - Google Analytics