关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » MySQL »MySQL常见问题大汇总

    MySQL常见问题大汇总

    2010-05-13 13:27:00 出处:ITJS
    分享

    以下的文章主要介绍的是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搭配之最佳组合)时的一些常见错误

    MySQL(和PHP搭配之最佳组合) server has gone away 

    常见的原因是服务器超时了并且关闭了连接。缺省地,如果没有事情发生,服务器在 8个小时后关闭连接。你可在启动MySQL(和PHP搭配之最佳组合)d时通过设置wait_timeout变量改变时间限制。

    如果MySQL(和PHP搭配之最佳组合)d得到一个太大或不正常的包,它认为客户出错了并关闭连接。

    Can't connect to [local] MySQL(和PHP搭配之最佳组合) server 

    通常意味着没有一个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命令中。

    Host '...' is blocked错误  Host 'hostname' is blocked because of many connection errors.  Unblock with 'MySQL(和PHP搭配之最佳组合)admin flush-hosts'  

    这意味着,MySQL(和PHP搭配之最佳组合)d已经得到了大量(max_connect_errors)的主机'hostname'的在中途被中断了的连接请求。在max_connect_errors次失败请求后,MySQL(和PHP搭配之最佳组合)d认定出错了(象来字一个黑客的攻击),并且阻止该站点进一步的连接,直到某人执行命令MySQL(和PHP搭配之最佳组合)admin flush-hosts。

    缺省地,MySQL(和PHP搭配之最佳组合)d在10个连接错误后阻塞一台主机。你可以通过象这样启动服务器很容易地调整它:

    shell> safe_MySQL(和PHP搭配之最佳组合)d -O max_connect_errors=10000 & 

    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错误

    Found wrong password for user: 'some_user@some_host'; Ignoring user 

    这意味着在MySQL(和PHP搭配之最佳组合)d启动时或在它再次装载权限表时,它在user表中找到了一个有一个无效口令的条目。结果,条目简单地被权限系统忽略。

    MySQL常见问题集锦之七:Table 'xxx' doesn't 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 * 检索列,因为被返回的列的顺序永远不能保证;对数据库的一个简单改变可能导致应用程序相当有戏剧性地失败。

    可以使用如下方法改变:

    以正确的列顺序创建一张新表。

    执行INSERT INTO new_table SELECT fields-in-new_table-order FROM old_table.  

    删除或改名old_table。

    ALTER TABLE new_table RENAME old_table。  

    数据库复制

    MySQL(和PHP搭配之最佳组合)(至今)没有数据库复制,但是有一些如何实现的信息。

    复制一个数据库最一般的方法是使用更新日志。

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    帝国CMS7.5编辑器上传图片取消宽高的三种方法

    帝国cms如何自动生成缩略图的实现方法

    Windows 12即将到来,将彻底改变人机交互

    帝国CMS 7.5忘记登陆账号密码怎么办?可以phpmyadmin中重置管理员密码

    帝国CMS 7.5 后台编辑器换行,修改回车键br换行为p标签

    Windows 11 版本与 Windows 10比较,新功能一览

    Windows 11激活产品密钥收集及专业版激活方法

    如何从 Windows 11 中完全删除/卸载 OneNote?无解!

    抖音安全与信任开放日:揭秘推荐算法,告别单一标签依赖

    ultraedit编辑器打开文件时,总是提示是否转换为DOS格式,如何关闭?

    IT头条

    华为Pura80系列新机预热,余承东力赞其复杂光线下的视频拍摄实力

    01:28

    阿里千问3开源首战告捷:全球下载破千万,国产AI模型崛起新高度!

    01:22

    DeepSeek R1小版本试升级:网友实测编程能力已达到国际一线水平

    23:15

    NVIDIA 与 Dell 合作,大规模交付 Blackwell AI 系统

    20:52

    Cerebras 以最快的 Llama 4 Maverick 性能引领 LLM 推理竞赛

    20:51

    技术热点

    PHP中的随机性——你觉得自己幸运吗?

    搞定Ubuntu Linux下WPA无线上网

    Java使用内存映射实现大文件的上传

    MySQL安全性指南

    MySQL两项性能的基本测试浅谈

    教您使用UniqueIdentifier选取SQL Server主键

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。