MySQL常见问题大汇总 |
本文标签:MySQL常见问题 以下的文章主要介绍的是MySQL常见问题集锦,我们一共分成七大块对其进行说明,我们大家都知道MySQL数据库在是实际应用中的比例远少于Oracle,之所是这样的,肯定有它的不足之处 。 MySQL常见问题集锦之一: MySQL(和PHP搭配之最佳组合)总是崩溃 首先你应该试着找出问题MySQL(和PHP搭配之最佳组合)d守护进程是否死掉或你的问题是否与你的客户有关 。你可以用MySQL(和PHP搭配之最佳组合)admin version检查你的MySQL(和PHP搭配之最佳组合)d服务器正常执行了多长时间,如果MySQL(和PHP搭配之最佳组合)d死了,你可以在文件“MySQL(和PHP搭配之最佳组合)-data-directory/hostname.err”中找到其原因 。 使用MySQL(和PHP搭配之最佳组合)时的一些常见错误
常见的原因是服务器超时了并且关闭了连接 。缺省地,如果没有事情发生,服务器在 8个小时后关闭连接 。你可在启动MySQL(和PHP搭配之最佳组合)d时通过设置wait_timeout变量改变时间限制 。 如果MySQL(和PHP搭配之最佳组合)d得到一个太大或不正常的包,它认为客户出错了并关闭连接 。
通常意味着没有一个MySQL(和PHP搭配之最佳组合)服务器运行在系统上或当试图连接MySQL(和PHP搭配之最佳组合)d服务器时,你正在使用一个错误的套接字文件或TCP/IP端口 。 检查(使用ps)服务器上是否有一个名为MySQL(和PHP搭配之最佳组合)d的进程启动 如果一个MySQL(和PHP搭配之最佳组合)d进程正在运行,可以通过尝试这些不同的连接来检查服务器 shell> MySQL(和PHP搭配之最佳组合)admin version shell> MySQL(和PHP搭配之最佳组合)admin variables shell> MySQL(和PHP搭配之最佳组合)admin -h `hostname` version variables shell> MySQL(和PHP搭配之最佳组合)admin -h `hostname` --port=3306 version shell> MySQL(和PHP搭配之最佳组合)admin -h ip for your host version shell> MySQL(和PHP搭配之最佳组合)admin --socket=/tmp/MySQL(和PHP搭配之最佳组合).sock version 注意hostname命令使用反引号“`”而非正引号“”;这些导致hostname输出(即,当前主机名)被代替进MySQL(和PHP搭配之最佳组合)admin命令中 。
这意味着,MySQL(和PHP搭配之最佳组合)d已经得到了大量(max_connect_errors)的主机hostname的在中途被中断了的连接请求 。在max_connect_errors次失败请求后,MySQL(和PHP搭配之最佳组合)d认定出错了(象来字一个黑客的攻击),并且阻止该站点进一步的连接,直到某人执行命令MySQL(和PHP搭配之最佳组合)admin flush-hosts 。 缺省地,MySQL(和PHP搭配之最佳组合)d在10个连接错误后阻塞一台主机 。你可以通过象这样启动服务器很容易地调整它:
MySQL常见问题集锦之二:Too many connections错误 意味着已经有max_connections个客户连接了MySQL(和PHP搭配之最佳组合)d服务器 。 如果你需要比缺省(100)更多的连接,那么你应该重启MySQL(和PHP搭配之最佳组合)d,用更大的 max_connections 变量值 。 MySQL常见问题集锦之三:Out of memory错误 MySQL(和PHP搭配之最佳组合): Out of memory at line 42, malloc.c MySQL(和PHP搭配之最佳组合): needed 8136 byte (8k), memory in use: 12481367 bytes (12189k) ERROR 2008: MySQL(和PHP搭配之最佳组合) client ran out of memory 注意,错误指向了MySQL(和PHP搭配之最佳组合)客户MySQL(和PHP搭配之最佳组合) 。这个错误的原因很简单,客户没有足够的内存存储全部结果 。 首先检查你的查询是否正确 MySQL常见问题集锦之四:Packet too large错误 一个MySQL(和PHP搭配之最佳组合)客户或MySQL(和PHP搭配之最佳组合)d服务器得到一个比max_allowed_packet个字节长的包 可以通过用MySQL(和PHP搭配之最佳组合) --set-variable=max_allowed_packet=8M指定一个更大的缓冲区来启动客户程序 。 MySQL常见问题集锦之五:The table is full错误 这个错误发生在内存临时表变得比tmp_table_size字节大时 。 Commands out of sync in client错误 正在以错误的次序调用客户函数! MySQL常见问题集锦之六:Ignoring user错误
这意味着在MySQL(和PHP搭配之最佳组合)d启动时或在它再次装载权限表时,它在user表中找到了一个有一个无效口令的条目 。结果,条目简单地被权限系统忽略 。 MySQL常见问题集锦之七:Table xxx doesnt exist错误 数据库和表名件是区分大小写的!可以用SHOW TABLES检b查你在当前数据库中有哪个表 。
从一个文本文件运行SQL命令 可以把SQL命令放在一个文件中并且告诉MySQL(和PHP搭配之最佳组合)从该文件读取其输入:创造一个文本文件“text_file”,它包含要执行的命令 。然后如下调用MySQL(和PHP搭配之最佳组合): shell> MySQL(和PHP搭配之最佳组合) database < text_file 或 shell> MySQL(和PHP搭配之最佳组合) < text_file 启动有USE db_name语句的文本文件 。
怎样重新设置一个忘记的口令 如果忘记了MySQL(和PHP搭配之最佳组合)的root用户的口令,可以使用如下方法恢复: 通过发送一个kill(不是kill -9)到MySQL(和PHP搭配之最佳组合)d服务器来关闭MySQL(和PHP搭配之最佳组合)d服务器 。pid 被保存在一个.pid文件中,通常在MySQL(和PHP搭配之最佳组合)数据库目录中: kill `cat /MySQL(和PHP搭配之最佳组合)-data-directory/hostname.pid` 你必须是一个UNIX root用户或运行服务器的相同用户做这个 。 使用--skip-grant-tables选项重启MySQL(和PHP搭配之最佳组合)d 。 用MySQL(和PHP搭配之最佳组合) -h hostname MySQL(和PHP搭配之最佳组合)连接MySQL(和PHP搭配之最佳组合)d服务器并且用一条GRANT命令改变口令 。见7.26 GRANT和REVOKE句法 。也可以用MySQL(和PHP搭配之最佳组合)admin -h hostname -u user password new password 进行 。 用MySQL(和PHP搭配之最佳组合)admin -h hostname flush-privileges或用SQL命令FLUSH PRIVILEGES来装载权限表 。
使用DATE列的问题 DATE值的格式是YYYY-MM-DD 。
改变一张表中列的顺序 在一个应用程序中,应该决不基于他们的位置使用SELECT * 检索列,因为被返回的列的顺序永远不能保证;对数据库的一个简单改变可能导致应用程序相当有戏剧性地失败 。 可以使用如下方法改变: 以正确的列顺序创建一张新表 。
删除或改名old_table 。
数据库复制 MySQL(和PHP搭配之最佳组合)(至今)没有数据库复制,但是有一些如何实现的信息 。 复制一个数据库最一般的方法是使用更新日志 。 |