远程客户端连接MysqL数据库太慢解决方案

时间:2019-05-15 13:23:36下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《远程客户端连接MysqL数据库太慢解决方案》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《远程客户端连接MysqL数据库太慢解决方案》。

第一篇:远程客户端连接MysqL数据库太慢解决方案

远程客户端连接MysqL数据库太慢解决方案

远程客户端连接MysqL数据库太慢解决方案

局域网客户端访问mysql 连接慢问题解决。

cd /etc/mysql

vi my.conf

[mysqld]

skip-name-resolve

此选项禁用了DNS解析,连接速度会快很多。

不过,这样的话就不能在MySQL的授权表中使用

主机名了而只能用ip格式。

第二篇:MySQL数据库连接超时(Wait_timeout)问题总结

当应用程序和数据库建立连接时,如果超过了8个小时,应用程序不去访问数据库,数据库就会出现断掉连接的现象。这时再次访问就会抛出异常.一般的解决方法大多是在数据库连接字符串中增加“autoReconnect=true ”选项。但是这只对mysql4以前的版本有效。在最新的mysql中是无效的。其实要解决这个问题也有一个简单的方法,就是修改mysql的启动参数。缺省情况下mysql的timeout时间是28800秒,正好是8小时,增加一个0就可以了。决定从根源入手,设置mysql的wait_timeout为31536000(一年),再来试试。set-variable=wait_timeout=31536000 set-variable=interactive_timeout=31536000 问题得到了解决 想了深入解一下mysql的工作原理

百度了一下Google发现很多人都出现过这种问题,大多是配置hibernate时候出的问题,可惜我的项目中没有使用到hibernate只是简单的自己配了一个连接池,所以综合了问题的关键所在改了一下数据库配置,在这里暂且记录一下,以后备用。

Mysql服务器默认的“wait_timeout”是8小时,也就是说一个connection空闲超过8个小时,Mysql将自动断开该 connection。这就是问题的所在。

最近碰到了这个问题,检查后发现数据库连接池中保存的连接超时后失效了,下面是官方的解释 mysql gone-away

从Mysql 5.x的某个版本之后,MySQL的自动关闭空闲连接的特性被修改了,假如一个连接空闲到超时时间(默认28000秒8小时),再次发起的Reconnect重新连接请求不会被接受,需要重新建立新连接,这就导致了SER的重连机制不能正常工作:SER只会在需要操作数据库时去使用同一个连接接口,断开了则发起重新连接请求,而且这个问题短期内SER也不能够解决。

下文中将具体讲述处理的方法:

1.使用Mysql 4.0或4.1版本,如果没有用到Mysql 5的一些新特性比如存储过程触发器之类。

2.定时重启Mysql服务器或Ser(由于本问题可能同样会影响到其它一些需要Mysql支持的服务器程序,所以重启Mysql服务器为好,但需要检测Mysql服务器不被使用的一个时间重启比较难确定)

3.设置my.cnf,有mysqld字段内增加参数:

[mysqld]port = 3306socket = /tmp/mysql.sockwait_timeout= 500000interactive_timeout = 500000(500000秒约五六天的超时时间,可根据实际需要选择一个数据库可能空闲的最长时间稍大的时间值。)重启Mysqld应用即可,也可以在执行mysqld时加-o wait_timeout=500000参数同样效果。

在MySQL客户端show variable时应该可以看到最后一条从默认的wait_time=28000变成500000了。

(假如重启Mysqld不生效,可以重启机子)

第三篇:Mysql数据库学习心得

Mysql数据库学习心得(1)

由于工作中需要使用mysql,笔者通过网上学习,动手实践,终于从一个“数据库菜鸟”变成了能熟练操作mysql的“准大虾”了,:)。现将学习心得整理如下。

MySQL是完全网络化的跨平台关系型数据库系统,一个真正的多用户、多线程SQL数据库服务器,同时是具有客户机/服务器体系结构的分布式数据库管理系统。它具有功能强、使

用简便、管理方便、运行速度快、安全可靠性强等优点,用户可利用许多语言编写访问MySQL数据库的程序,对于中、小型应用系统是非常理想的。除了支持标准的ANSI SQL语句,更重要的是,它还支持多种平台,而在Unix系统上该软件支持多线程运行方式,从而能获得相当好的性能。对于不使用Unix的用户,它可以在Windows NT系统上以系统服务方式运行,或者在Windows 95/98系统上以普通进程方式运行。而在Unix/Linux系统上,MySQL支持多线程运行方式,从而能获得相当好的性能,而且它是属于开放源代码软。

MySQL是以一个客户机/服务器结构的实现,它由一个服务器守护程序mysqld和很多不同的客户程序和库组成,MySQL的执行性能非常高,运行速度非常快,并非常容易使用,是一个非常棒的数据库。MySQL的官方发音是“My Ess Que Ell”(不是MY-SEQUEL)。

一.获得MySQL

首先必须下载MySQL。Mysql的官方网站是:www.xiexiebang.comf copy为c:my.cnf,并把c:mysqlibgwinb19.dll copy到winntsystem32。

3。启动mysql的方法是:

c:mysqlinmysqld-shareware--install

net start mysql

这么简单,就可以启动了。

4。更改超级用户(root)的密码:

C:mysqlinmysql mysql

mysql> UPDATE user SET password=PASSWORD('your password')swheresuser='root';

mysql> QUIT

C:mysqlinmysqladmin reload

使用命令C:mysqlinmysqlshow去看看检测一下。在这里应该显示:

+-----------+

| Databases |

+-----------+

| mysql |

| test |

+-----------+

看到这些信息这一步就证明没问题了

再来:

C:mysqlinmysqlshow--user=root--password=your password mysql

在这里应该显示:

Database: mysql

+--------------+

| Tables |

+--------------+

| columns_priv |

| db |

| host |

| tables_priv |

| user |

+--------------+

一切搞定!

5。C:mysqlinmysqladmin version status proc

应该可以看到这些版本信息的:

mysqladmin Ver 8.0 Distrib 3.22.32, for Win95/Win98 on i586

TCX Datakonsult AB, by Monty

Server version 3.22.32-shareware-debug

Protocol version 10

Connection localhost via TCP/IP

TCP port 3306

Uptime: 1 hour 29 min 30 sec

Threads: 1 Questions: 72 Slow queries: 0 Opens: 16 Flush tables: 1 Open tables: 0 Memory in use: 16423K Max memory

used: 16490K

Uptime: 5370 Threads: 1 Questions: 72 Slow queries: 0 Opens: 16 Flush tables: 1 Open tables: 0 Memory in use: 16423K

Max memory used: 16490K

+----+------+-----------+----+---------+------+-------+------------------+

| Id | User | Host | db | Command | Time | State | Info |

+----+------+-----------+----+---------+------+-------+------------------+

| 35 | ODBC | localhost | | Query | 0 | | show processlist |

+----+------+-----------+----+---------+------+-------+------------------+

接着,用show databases命令可以将安装的数据库列出来:

mysql> show databases;

你就可以看到:

+----------+

| Database |

+----------+

| mysql |

| test |

+----------+ rows in set(0.00 sec)

如果一切正常的话,那说明MySQL可以完全工作了!如果要退出程序,输入:exit

mysql> exit;

Bye

Mysql数据库学习心得(3)------------------

三.Mysql常识

(一)字段类型

1.INT[(M)]

正常大小整数类型

2.DOUBLE[(M,D)] [ZEROFILL]

正常大小(双精密)浮点数字类型

3.DATE

日期类型。支持的范围是'1000-01-01'到'9999-12-31'。MySQL以'YYYY-MM-DD'格式来显示DATE值,但是允许你使用字符串或数字把值赋给

DATE列

4.CHAR(M)

定长字符串类型,当存储时,总是是用空格填满右边到指定的长度

5.BLOB TEXT

BLOB或TEXT类型,最大长度为65535(2^16-1)个字符。

6.VARCHAR

变长字符串类型,最常用的类型。

(二)基本操作

1:显示数据库

mysql>SHOW DATABASES;

2:当前选择的数据库,mysql> SELECT DATABASE();

+------------+

| DATABASE()|

+------------+

| test |

+------------+

3.当前数据库包含的表信息:

mysql> SHOW TABLES;

+---------------------+

| Tables in test |

+---------------------+

| mytable1 |

| mytable2 |

+---------------------+

4.获取表结构

mysql> desc mytable1;

+---------+-------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+---------+-------------+------+-----+---------+-------+

| s1 | varchar(20)| YES | | NULL | |

+---------+-------------+------+-----+---------+-------+

5.创建表

表是数据库的最基本元素之一,表与表之间可以相互独立,也可以相互关联。创建表的基本语法如下:

create table table_name

(column_name datatype {identity |null|not null},…)

其中参数table_name和column_name必须满足用户数据库中的识别器(identifier)的要求,参数datatype是一个标准的SQL类型或由用户数

据库提供的类型。用户要使用non-null从句为各字段输入数据。

create table还有一些其他选项,如创建临时表和使用select子句从其他的表中读取某些字段组成新表等。还有,在创建表是可用PRIMARY

KEY、KEY、INDEX等标识符设定某些字段为主键或索引等。书写上要注意:在一对圆括号里的列出完整的字段清单。字段名间用逗号隔开

。字段名间的逗号后要加一个空格。最后一个字段名后不用逗号。所有的SQL陈述都以分号“;”结束。

例:

mysql>CREATE TABLE guest(name varchar(10),sex varchar(2),age int(3),career varchar(10));

6.创建索引

索引用于对数据库的查询。一般数据库建有多种索引方案,每种方案都精于某一特定的查询类。索引可以加速对数据库的查询过程。创建

索引的基本语法如下:

create index index_name

on table_name(col_name[(length)],...)

例:

mysql> CREATE INDEX number ON guest(number(10));

7.执行查询

查询是使用最多的SQL命令。查询数据库需要凭借结构、索引和字段类型等因素。大多数数据库含有一个优化器(optimizer),把用户的查

询语句转换成可选的形式,以提高查询效率。

值得注意的是MySQL不支持SQL92标准的嵌套的where子句,即它只支持一个where子句。其基本语法如下:

SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY]

[DISTINCT | DISTINCTROW | ALL]

select_expression,...[INTO {OUTFILE | DUMPFILE} 'file_name' export_options]

[FROM table_references

[WHERE where_definition]

[GROUP BY col_name,...]

[HAVING where_definition]

[ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] ,...]

[LIMIT [offset,] rows]

[PROCEDURE procedure_name] ]

其中where从句是定义选择标准的地方,where_definition可以有不同的格式,但都遵循下面的形式:

字段名操作表达式

字段名操作字段名

在第一种形式下,标准把字段的值与表达式进行比较;在第二种形式下,把两个字段的值进行比较。根据所比较的数据类型,search_condition中的操作可能选以下几种:

=检查是否相等

!=检查是否不等

>(或>=)检查左边值是否大于(或大于等于)右边值

<(或<=)检查左边值是否小于(或小于等于)右边值

[not] between检查左边值是否在某个范围内

[not] in检查左边是否某个特定集的成员

[not] like检查左边是否为右边的子串

is [not] null检查左边是否为空值

在这里,可以用通配符_代表任何一个字符,%代表任何字符串。使用关键字、和可以生成复杂的词,它们运行检查时使用

布尔表达式的多重标准集。

例:

mysql> select t1.name, t2.salary from employee AS t1, info AS t2swherest1.name = t2.name;

mysql> select college, region, seed from tournament

ORDER BY region, seed;

mysql> select col_name from tbl_nameswherescol_name > 0;

8.改变表结构

在数据库的使用过程中,有时需要改变它的表结构,包括改变字段名,甚至改变不同数据库字段间的关系。可以实现上述改变的命令是

alter,其基本语法如下:

alter table table_name alter_spec [, alter_spec...]

例:

mysql> alter table dbname add column userid int(11)not null primary key auto_increment;

这样,就在表dbname中添加了一个字段userid,类型为int(11)。

9.修改表中数据

在使用数据库过程中,往往要修改其表中的数据,比如往表中添加新数据,删除表中原有数据,或对表中原有数据进行更改。它们的基本

语法如下:

数据添加:

insert [into] table_name [(column(s))]

values(expression(s))

例:

mysql>insertsintosmydatabase values('php','mysql','asp','sqlserver','jsp','oracle');Mysql数据库学习心得(4)------------------

10.表的数据更新

(1)一次修改一个字段,再次注意语法。文本需要加引号但数字不要。

mysql>update table01 set field03='new info'swheresfield01=1;

Query OK, 1 row affected(0.00 sec)

(2)一次改变多个字段,记住在每一个更新的字段间用逗号隔开。

mysql>update table01 set field04=19991022, field05=062218swheresfield01=1;

Query OK, 1 row affected(0.00 sec)

(3)一次更新多个数据

mysql>update table01 set field05=152901swheresfield04>19990101;

Query OK, 3 rows affected(0.00 sec)

11.删除数据

mysql>delete from table01swheresfield01=3;

Query OK, 1 row affected(0.00 sec)

12.导入数据库表

(1)创建.sql文件

(2)先产生一个库如auction.c:mysqlin>mysqladmin-u root-p creat auction,会提示输入密码,然后成功创建。

(3)导入auction.sql文件

c:mysqlin>mysql-u root-p auction < auction.sql。

通过以上操作,就可以创建了一个数据库auction以及其中的一个表auction。

13.mysql数据库的授权

mysql>grant select,insert,delete,create,drop

on *.*(或test.*/user.*/..)

to用户名@localhost

identified by '密码';

如:新建一个用户帐号以便可以访问数据库,需要进行如下操作:

mysql> grant usage

-> ON test.*

-> TO testuser@localhost;

Query OK, 0 rows affected(0.15 sec)

此后就创建了一个新用户叫:testuser,这个用户只能从localhost连接到数据库并可以连接到test数据库。下一步,我们必须指定

testuser这个用户可以执行哪些操作:

mysql> GRANT select, insert, delete,update

-> ON test.*

-> TO testuser@localhost;

Query OK, 0 rows affected(0.00 sec)

此操作使testuser能够在每一个test数据库中的表执行SELECT,INSERT和DELETE以及UPDATE查询操作。现在我们结束操作并退出MySQL客户

程序:

mysql> exit

Bye

14.授权MySQL用户密码

MySQL数据库的默认用户名为“root”(MS SQL Server的sa相似),密码默认为空。在DOS提示符(注 意,不是mysql提示符)下输入

c:mysqlin>“mysqladmin-u root-p password newpassword

回车后会提示你输入原来的密码,由于原来密码为空,直接回车,root用户的密码便改为”newpassword“了。

Mysql数据库学习心得(5)------------------

四.安装phpMyAdmin

MySQL图形界面管理器phpMyAdmin是一套以php3写成,针对MySQL数据库系统的Web管理界面。它可以很方便地以图形化界面,来对MySQL数据库里的字段、数据进行增加、删除等的动作,更可以做数据库本身的增删管理;phpMyAdmin可以管理整个MySQL服务器(需要超级用户),也可以管理单个数据库。另外,您也可以通过使用这个图形化界面来学习SQL正确的语法,直至熟练掌握。那要等到你看过MySQL手册中相关的部分。你可以到http://www.phpwizard.net/phpMyAdmin/去下载最新的版本。

首先,将phpMyAdmin软件包解到一个目录下。

1.修改文档config.inc.php3。

将原来的设定:

§cfgServers[1]['host'] = '';// MySQL hostname

§cfgServers[1]['port'] = '';// MySQL port-leave blank fordefault port

§cfgServers[1]['adv_auth'] = false;// Use advanced authentication?

§cfgServers[1]['stduser'] = '';// MySQL standard user(only needed with advanced auth)

§cfgServers[1]['stdpass'] = '';// MySQL standard password(only needed with advanced auth)

§cfgServers[1]['user'] = '';// MySQL user(only needed withbasic auth)

§cfgServers[1]['password'] = '';// MySQL password(only needed with basic auth)

§cfgServers[1]['only_db'] = '';// If set to a db-name, only this db is accessible

§cfgServers[1]['verbose'] = '';// Verbose name for this host-leave blank to show the hostname

:

:

require(”english.inc.php3“);

修改成:

§cfgServers[1]['host'] = 'MySQL Server的hostname';//填入您的MySQL Server的主机名称

§cfgServers[1]['port'] = '';//填入连结MySQL的port,不填则以预设的port进行连结

§cfgServers[1]['adv_auth'] = true;//改成true则进入phpMyAdmin必须先身份认证

§cfgServers[1]['stduser'] = 'root';// MySQL使用者的帐号

§cfgServers[1]['stdpass'] = '密码';// MySQL使用者的密码

§cfgServers[1]['user'] = 'root';// MySQL管理帐号

§cfgServers[1]['password'] = '密码';// MySQL管理密码

§cfgServers[1]['only_db'] = '';//指定管理的资库名称,不填则可以管理整个Server

§cfgServers[1]['verbose'] = '';//指定MySQL的名称,不填则使用系统本身的hostname

:

:

require(”chinese_gb.inc.php3");//将语言改成中文

说明:

(1)因本管理接口,可以以一个接口,管理多个MySQL Server,所以可以在config.inc.php3中找到

§cfgServers[1]...§cfgServers[1]...§cfgServers[1]...:

§cfgServers[2]...§cfgServers[2]...§cfgServers[2]...其中[1]代表第一个MySQL Server,[2]代表第二个MySQL Server,您要管理的MySQL Server超过三台以上,您可以依照同样的?述,增加[4].....下去!

(2)若您的MySQL Server与http Server是同一台,则§cfgServers[1]['host'] =可直接填入localhost。

最后,打开流览器,输入你的网址/phpMyAdmin之后您会看到一个密码验证的小窗口,输入您的MySQL管理帐号及密码,即可成功地看到phpMyAdmin的管理画面。通过phpmyadmin,你就可以图形化的、方便的管理你的所有数据库了。

五.小结

通过以上的学习和操作,终于可以自由操作mysql数据库了,也可以轻车熟路的使用php或者asp调用mysql了。最后,笔者要特别感谢开发了mysql并且免费贡献的天才以及在网上提供mysql使用说明的大虾们。

第四篇:mysql数据库要点总结

查询(R)Selec子句

书写顺序

Select distinct:要返回的列或表达式 From:从中检索数据的表 Where:行级过滤/分组前过滤 group by:分组说明

having:组级过滤/分组后过滤 order by:输出排序顺序desc/asc limit start, count:要检索的行数 limit 3,4 从第3行开始的连续4行

SELECT order_num,sum(quantity*item_price)ordertotal FROM orderitems WHEREorder_numBETWEEN20005AND 20009GROUP BY order_num HAVINGsum(quantity*item_price)>=50ORDER BYordertotalDESCLIMIT4;执行顺序

From表名->inner/left/right/ join on->where->group by->select distinct *->having->order by->limit start, count 插入Insert into(C)INSERT INTO students(name)values(‘杨过’),(‘小龙女’);更新(U)Update UPDATE customers SETcust_email = ‘elmer@fudd.com’WHEREcust_id = 10005;删除(D)Delete DELETE FROM customers WHEREcust_id = 10006;Truncate删除原来的表并重新创建一个表,删除标的全部内容时效率高。

操作表

创建CREATE TABLE customers(Cust_idint not null auto_increment primary key,Cust_name char(50)not null,Cust_addresschar(50)null)engine = innoDB;更新ALTER TABLE删除DROP TABLEcustomers2;重命名RENAME TABLE customers2 TO customers;操作数据库

创建CREATE DATABASE xxx charset = utf8;删除DROP DATABASEXXX;切换USE XXX;查看SHOW DATABASES;关联查询

INNER/LEFT/RIGHTJOIN ON SELECT students.name,subjects.title,scores.scoreFROM scores INNER JOIN students ONscores.stuid = students.id INNER JOIN subjects ONscores.subid = subjects.id;

第五篇:PHP MySql乱码解决方案

PHP乱码?Mysql乱码?怎么解决?

PHP乱码或者mysql乱码,多半是因为没有统一编码,要解决PHP/mysql乱码,只要做到三码合一即可.所谓三码,是指文件编码,页面编码声明和数据库字符集,要使用相同的编码,如全部为utf-8.怎么做到三码合一?下面以utf-8为例,说明如何统一编码.1.网页文件编码保存为utf-8无BOM

记事本,保存文件的时候选择“编码”为utf-8

editPlus,保存时选择“encoding”为utf-8

UEStudio保存时选择“格式”为utf-8无BOM

2.PHP页面内部使用header('Content-type : text/html;Charset=UTF-8');声明页面编码为utf-8

在html头部写入来声明页面编码为utf-8

3.PHP页面中连接数据库服务器后执行sql查询前使用以下代码先将字符集设置为utf-8 mysql_query('SET NAMES utf8');[或mysqli,具体代码这里不再写了]

4.创建数据表的时候将默认编码设置为utf8,将字符校对(callate)设置为utf8_general_ci CREATE TABLE IF NOT EXISTS `name`(....代码....)ENGINE InnoDB DEFAULT CHARSET utf8 COLLATE utf8_general_ci

做到这四点,相信你的网页和数据库不会再乱码.

下载远程客户端连接MysqL数据库太慢解决方案word格式文档
下载远程客户端连接MysqL数据库太慢解决方案.doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐

    远程连接sql server 2000服务器的解决方案

    远程连接sql server 2000服务器的解决方案一看ping 服务器Ip能否ping通,远程连接sql server 2000服务器的解决方案。这个实际上是看和远程sql server 2000服务器的物理连接是......

    mysql数据库常用语句大全

    mysql数据库常用语句 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)......

    JDBC连接数据库经验总结

    Java数据库连接(JDBC)由一组用 Java 编程语言编写的类和接口组成。JDBC 为工具/数据库开发人员提供了一个标准的 API,使他们能够用纯Java API 来编写数据库应用程序。然而各个......

    MySQL中文模糊搜索解决方案

    在 MySQL下,在进行中文模糊检索时,经常会返回一些与之不相关的记录,如查找 "%a%" 时,返回的可能有中文字符,却没有a字符存在。本人以前也曾遇到过类似问题,经详细阅读MySQL的Manua......

    JDBC方式连接数据库心得体会

    1、在新建好的数据库中建立一张名字为UserTable的数据表,定义好各个字段的数据类型和主键。 表的设计结构如下:(仅作测试使用) UserTable: 其中UserId为主键。 2、在表中写入适当......

    远程连接sql server 2000服务器的解决方案(精选5篇)

    远程连接sql server 2000服务器的解决方案 一 看ping 服务器IP能否ping通。 这个实际上是看和远程sql server 2000服务器的物理连接是否存在。如果不行,请检查网络,查看配置,当......

    网络数据库讲稿(客户端开发编程)

    网络数据库讲稿(14) 3/26/2013 SQL Server客户端开发与编程 一、引言 1.编程模式:C/S模式和B/S模式。 2.客户端编程语言:ASP,VB,VC,VFP,PB,Delphi,Access,ASP,JSP等,都可访问SQL数据库。......

    客户端连接不上服务器总结(shqb)

    客户端连接不上服务器 概述:大体分为下面三类原因: 一、网络问题 二、安全问题 三、数据库配置问题 魏老师补充: 网络版、单机版 单独一个客户端出现问题,则说明服务器正常。 该......