<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[阿Tim日志]]></title> 
<link>https://atim.cn/index.php</link> 
<description><![CDATA[专业的php开发者.开发团队的带队人]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[阿Tim日志]]></copyright>
<item>
<link>https://atim.cn/post//</link>
<title><![CDATA[mysql常见问题]]></title> 
<author>bkkkd &lt;partybase@gmail.com&gt;</author>
<category><![CDATA[数据应用]]></category>
<pubDate>Fri, 16 Dec 2005 03:20:00 +0000</pubDate> 
<guid>https://atim.cn/post//</guid> 
<description>
<![CDATA[ 
	一、认知篇 <br/>　　MYSQL初学者使用指南与介绍 <br/>　　学习MySQL常用操作命令 <br/>　　学习MySQL多表操作和备份处理<br/>　　Mysql数据库学习心得(1)<br/>　　Mysql数据库学习心得(2)<br/><br/><br/>　　二、常见问题集锦<br/><br/>　　MySQL总是崩溃 <br/><br/>　　首先你应该试着找出问题mysqld守护进程是否死掉或你的问题是否与你的客户有关。你可以用mysqladmin version检查你的mysqld服务器正常执行了多长时间，如果mysqld死了，你可以在文件“mysql-data-directory/'hostname'.err”中找到其原因。<br/><br/>　　使用MySQL时的一些常见错误 <br/><br/>　　MySQL server has gone away<br/><br/>　　常见的原因是服务器超时了并且关闭了连接。缺省地，如果没有事情发生，服务器在 8个小时后关闭连接。你可在启动mysqld时通过设置wait_timeout变量改变时间限制。<br/><br/>　　如果mysqld得到一个太大或不正常的包，它认为客户出错了并关闭连接。<br/><br/>　　Can't connect to [local] MySQL server<br/><br/>　　通常意味着没有一个MySQL服务器运行在系统上或当试图连接mysqld服务器时，你正在使用一个错误的套接字文件或TCP/IP端口。 <br/><br/>　　检查(使用ps)服务器上是否有一个名为mysqld的进程启动<br/><br/>　　如果一个mysqld进程正在运行，可以通过尝试这些不同的连接来检查服务器<br/><br/>shell> mysqladmin version<br/><br/>shell> mysqladmin variables<br/><br/>shell> mysqladmin -h `hostname` version variables<br/><br/>shell> mysqladmin -h `hostname` --port=3306 version<br/><br/>shell> mysqladmin -h 'ip for your host' version<br/><br/>shell> mysqladmin --socket=/tmp/mysql.sock version<br/><br/>　　注意hostname命令使用反引号“`”而非正引号“'”；这些导致hostname输出（即，当前主机名）被代替进mysqladmin命令中。<br/>　　Host '...' is blocked错误<br/><br/>Host 'hostname' is blocked because of many connection errors.<br/><br/>Unblock with 'mysqladmin flush-hosts'<br/><br/>　　这意味着，mysqld已经得到了大量(max_connect_errors)的主机'hostname'的在中途被中断了的连接请求。在max_connect_errors次失败请求后，mysqld认定出错了(象来字一个黑客的攻击)，并且阻止该站点进一步的连接，直到某人执行命令mysqladmin flush-hosts。<br/><br/>缺省地，mysqld在10个连接错误后阻塞一台主机。你可以通过象这样启动服务器很容易地调整它：<br/><br/>shell> safe_mysqld -O max_connect_errors=10000 &<br/><br/><br/>　　Too many connections错误<br/><br/>　　意味着已经有max_connections个客户连接了mysqld服务器。<br/><br/>　　如果你需要比缺省(100)更多的连接，那么你应该重启mysqld，用更大的 max_connections 变量值。<br/><br/><br/>　　Out of memory错误<br/><br/>mysql: Out of memory at line 42, 'malloc.c'<br/><br/>mysql: needed 8136 byte (8k), memory in use: 12481367 bytes (12189k)<br/><br/>ERROR 2008: MySQL client ran out of memory<br/><br/>　　注意，错误指向了MySQL客户mysql。这个错误的原因很简单，客户没有足够的内存存储全部结果。<br/><br/>　　首先检查你的查询是否正确<br/><br/>　　Packet too large错误 <br/><br/><br/>　　一个MySQL客户或mysqld服务器得到一个比max_allowed_packet个字节长的包<br/><br/>　　可以通过用mysql --set-variable=max_allowed_packet=8M指定一个更大的缓冲区来启动客户程序。<br/><br/><br/>　　The table is full错误<br/><br/>　　这个错误发生在内存临时表变得比tmp_table_size字节大时。<br/><br/>　　Commands out of sync in client错误<br/><br/>　　正在以错误的次序调用客户函数！<br/><br/>　　Ignoring user错误<br/><br/>Found wrong password for user: _user@some_host'">'some_user@some_host'; Ignoring user<br/><br/>　　这意味着在mysqld启动时或在它再次装载权限表时，它在user表中找到了一个有一个无效口令的条目。结果，条目简单地被权限系统忽略。<br/><br/>　　Table 'xxx' doesn't exist错误<br/><br/>　　数据库和表名件是区分大小写的！可以用SHOW TABLES检查你在当前数据库中有哪个表。<br/><br/><br/>　　从一个文本文件运行SQL命令 <br/><br/>　　可以把SQL命令放在一个文件中并且告诉mysql从该文件读取其输入：创造一个文本文件“text_file”，它包含要执行的命令。然后如下调用mysql：<br/><br/>shell> mysql database < text_file<br/><br/>　　或<br/><br/>shell> mysql < text_file<br/><br/>　　启动有USE db_name语句的文本文件。<br/><br/><br/>　　怎样重新设置一个忘记的口令 <br/><br/>　　如果忘记了MySQL的root用户的口令，可以使用如下方法恢复： <br/><br/>　　通过发送一个kill（不是kill -9)到mysqld服务器来关闭mysqld服务器。pid 被保存在一个.pid文件中，通常在MySQL数据库目录中：<br/><br/>　　kill `cat /mysql-data-directory/hostname.pid`<br/><br/>　　你必须是一个UNIX root用户或运行服务器的相同用户做这个。<br/><br/>　　使用--skip-grant-tables选项重启mysqld。 <br/><br/>　　用mysql -h hostname mysql连接mysqld服务器并且用一条GRANT命令改变口令。见7.26 GRANT和REVOKE句法。也可以用mysqladmin -h hostname -u user password 'new password' 进行。 <br/><br/>　　用mysqladmin -h hostname flush-privileges或用SQL命令FLUSH PRIVILEGES来装载权限表。 <br/><br/><br/>　　使用DATE列的问题 <br/><br/>　　DATE值的格式是'YYYY-MM-DD'。<br/><br/><br/>　　改变一张表中列的顺序 <br/><br/>　　在一个应用程序中，应该决不基于他们的位置使用SELECT * 检索列，因为被返回的列的顺序永远不能保证；对数据库的一个简单改变可能导致应用程序相当有戏剧性地失败。<br/><br/>　　可以使用如下方法改变：<br/><br/>　　以正确的列顺序创建一张新表。 <br/><br/>　　执行INSERT INTO new_table SELECT fields-in-new_table-order FROM old_table. <br/><br/>　　删除或改名old_table。 <br/><br/>　　ALTER TABLE new_table RENAME old_table。 <br/><br/>　　数据库复制 <br/><br/>　　MySQL(至今)没有数据库复制，但是有一些如何实现的信息。<br/><br/>　　复制一个数据库最一般的方法是使用更新日志。<br/><br/>　　数据库备份 <br/><br/>　　为了得到一个一致的备份，在相关的表上做一个LOCK TABLES。你只需一个读锁定；当你在数据库目录中做文件的一个拷贝时，这允许其他线程继续查询该表。如果你想要做一个SQL级的备份，你可以SELECT INTO OUTFILE。<br/><br/>　　备份一个数据库的另一个方法是使用mysqldump程序： <br/><br/>　　为你的数据库做一个完整的备份：<br/><br/>shell> mysqldump --tab=/path/to/some/dir --opt --full<br/><br/>　<br/>　　你也可以简单地拷贝所有的表文件(“*.frm”、“*.MYD”和“*.MYI”文件)，只要服务器不在更新任何东西。<br/><br/>　　停止mysqld如果它正在运行，然后以--log-update选项启动它。你将得到一个名为“hostname.n”形式的日志文件， 这里n是随着你每次执行mysqladmin refresh或mysqladmin flush-logs、FLUSH LOGS语句、或重启服务器而递增的一个数字。这些日志文件向你提供了在你执行mysqldump处后面进行的复制数据库改变的所需信息。 <br/><br/>　　如果你必须恢复一些东西，尝试首先用myisamchk -r恢复你的表。这应该处理所有情况的99.9%。如果myisamchk失败，尝试下列过程： <br/><br/><br/>　　恢复原来的mysqldump备份。 <br/><br/>　　执行下列命令以再次运行更新日志中的更改： <br/><br/>shell> ls -1 -t -r hostname.[0-9]* | xargs cat | mysql<br/><br/><br/>　　ls被用来以正确的顺序得到所有的日志文件。 <br/><br/><br/>　　你也可以与SELECT * INTO OUTFILE 'file_name' FROM tbl_name做有选择的备份并且用LOAD DATA INFILE 'file_name' REPLACE ...恢复。为了避免重复记录，在表中你需要一个PRIMARY KEY或UNIQUE键。当在唯一键值上一个新记录与一个老记录重复时，REPLACE关键词使得老记录用一个新记录替代。<br/><br/>　　三、MySQL惯用技巧<br/><br/>_blank>用delphi解决MySQL数据库中无图形界面的问题<br/>_blank>MySQL索引分析和优化 <br/>_blank>去掉MySQL中的噪声<br/>_blank>PHP页面时而工作，时而不工作<br/>_blank>创建一个带有MUL列的表<br/>_blank>MyISAM和外键支持<br/>_blank>添加并不存在于公司图表里的公司雇员<br/>_blank>MERGE图表的性能<br/>_blank>在同一台服务器上的MySQL和Active Directory<br/>_blank>更新和删除的层叠<br/>_blank>触发器和MySQL<br/>_blank>从处理日志中恢复记录<br/>_blank>分析索引<br/>_blank>带有子查寻的1064查寻错误<br/>_blank>得到错误1006： 不能生成数据库<br/>_blank>管理MySQL的GUI工具<br/>_blank>MySQL是关联的吗？<br/>_blank>将SQL Server的安装迁移到MySQL<br/>_blank>MySQL的存储过程支持<br/>_blank>MySQL中的SQL-- TEXT、DATE、和SET数据类型<br/>_blank>使用MySql <br/>
]]>
</description>
</item><item>
<link>https://atim.cn/post//#blogcomment</link>
<title><![CDATA[[评论] mysql常见问题]]></title> 
<author> &lt;user@domain.com&gt;</author>
<category><![CDATA[评论]]></category>
<pubDate>Thu, 01 Jan 1970 00:00:00 +0000</pubDate> 
<guid>https://atim.cn/post//#blogcomment</guid> 
<description>
<![CDATA[ 
	
]]>
</description>
</item>
</channel>
</rss>