<?xml version="1.0" encoding="utf-8"?><?xml-stylesheet type='text/xsl' href='http://jdlog.spaces.live.com/mmm2008-07-24_12.50/rsspretty.aspx?rssquery=en-US;http%3a%2f%2fjdlog.spaces.live.com%2ffeed.rss' version='1.0'?><rss version="2.0" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:msn="http://schemas.microsoft.com/msn/spaces/2005/rss" xmlns:live="http://schemas.microsoft.com/live/spaces/2006/rss" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:cf="http://www.microsoft.com/schemas/rss/core/2005" xmlns:wfw="http://wellformedweb.org/CommentAPI/"><channel><title>JDlog</title><description>首发：www.jimmydong.com    镜像：fz9493.blog.sohu.com</description><link>http://jdlog.spaces.live.com/</link><language>en-US</language><pubDate>Tue, 20 Mar 2007 01:29:21 GMT</pubDate><lastBuildDate>Tue, 20 Mar 2007 01:29:21 GMT</lastBuildDate><generator>Microsoft Spaces v1.1</generator><docs>http://www.rssboard.org/rss-specification</docs><ttl>60</ttl><live:identity><live:id>-294328527923311756</live:id><live:alias>jdlog</live:alias></live:identity><cf:listinfo><cf:group ns="http://schemas.microsoft.com/live/spaces/2006/rss" element="typelabel" label="Type" /><cf:group ns="http://schemas.microsoft.com/live/spaces/2006/rss" element="tag" label="Tag" /><cf:group element="category" label="Category" /><cf:sort element="pubDate" label="Date" data-type="date" default="true" /><cf:sort element="title" label="Title" data-type="string" /><cf:sort ns="http://purl.org/rss/1.0/modules/slash/" element="comments" label="Comments" data-type="number" /></cf:listinfo><item><title>MySQL: 诡异的MySQL server has gone away及其解决</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!253.entry</link><description>&lt;div&gt;
&lt;h3&gt;MySQL: 诡异的MySQL server has gone away及其解决&lt;/h3&gt;&lt;span&gt;jimmy | 15 三月, 2007 20:32&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;在Mysql执行show status，通常更关注缓存效果、进程数等，往往忽略了两个值：
&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Variable_name 
&lt;th&gt;Value 
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;Aborted_clients
&lt;td&gt;3792
&lt;tr&gt;
&lt;td&gt;Aborted_connects
&lt;td&gt;376&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;通常只占query的0.0x%，所以并不为人所重视。而且在传统Web应用上，query错误对用户而言影响并不大，只是重新刷新一下页面就OK了。最近的基础改造中，把很多应用作为service运行，无法提示用户重新刷新，这种情况下，可能就会影响到服务的品质。
&lt;p&gt;通过程序脚本的日志跟踪，主要报错信息为“MySQL server has gone away”。官方的解释是：
&lt;p&gt;The most common reason for the &lt;code&gt;MySQL server has gone away&lt;/code&gt; error is that the server timed out and closed the connection. 
&lt;p&gt;Some other common reasons for the &lt;code&gt;MySQL server has gone away&lt;/code&gt; error are: 
&lt;div&gt;
&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;You (or the db administrator) has killed the running thread with a &lt;code&gt;KILL&lt;/code&gt; statement or a &lt;span&gt;&lt;strong&gt;mysqladmin kill&lt;/strong&gt;&lt;/span&gt; command. 
&lt;li&gt;
&lt;p&gt;You tried to run a query after closing the connection to the server. This indicates a logic error in the application that should be corrected. 
&lt;li&gt;
&lt;p&gt;A client application running on a different host does not have the necessary privileges to connect to the MySQL server from that host. 
&lt;li&gt;
&lt;p&gt;You got a timeout from the TCP/IP connection on the client side. This may happen if you have been using the commands: &lt;code&gt;mysql_options(..., MYSQL_OPT_READ_TIMEOUT,...)&lt;/code&gt; or &lt;code&gt;mysql_options(..., MYSQL_OPT_WRITE_TIMEOUT,...)&lt;/code&gt;. In this case increasing the timeout may help solve the problem. 
&lt;li&gt;
&lt;p&gt;You have encountered a timeout on the server side and the automatic reconnection in the client is disabled (the &lt;code&gt;reconnect&lt;/code&gt; flag in the &lt;code&gt;MYSQL&lt;/code&gt; structure is equal to 0). 
&lt;li&gt;
&lt;p&gt;You are using a Windows client and the server had dropped the connection (probably because &lt;code&gt;wait_timeout&lt;/code&gt; expired) before the command was issued. 
&lt;p&gt;The problem on Windows is that in some cases MySQL doesn't get an error from the OS when writing to the TCP/IP connection to the server, but instead gets the error when trying to read the answer from the connection. 
&lt;p&gt;In this case, even if the &lt;code&gt;reconnect&lt;/code&gt; flag in the &lt;code&gt;MYSQL&lt;/code&gt; structure is equal to 1, MySQL does not automatically reconnect and re-issue the query as it doesn't know if the server did get the original query or not. 
&lt;p&gt;The solution to this is to either do a &lt;code&gt;mysql_ping&lt;/code&gt; on the connection if there has been a long time since the last query (this is what &lt;code&gt;MyODBC&lt;/code&gt; does) or set &lt;code&gt;wait_timeout&lt;/code&gt; on the &lt;span&gt;&lt;strong&gt;mysqld&lt;/strong&gt;&lt;/span&gt; server so high that it in practice never times out. 
&lt;li&gt;
&lt;p&gt;You can also get these errors if you send a query to the server that is incorrect or too large. If &lt;span&gt;&lt;strong&gt;mysqld&lt;/strong&gt;&lt;/span&gt; receives a packet that is too large or out of order, it assumes that something has gone wrong with the client and closes the connection. If you need big queries (for example, if you are working with big &lt;code&gt;BLOB&lt;/code&gt; columns), you can increase the query limit by setting the server's &lt;code&gt;max_allowed_packet&lt;/code&gt; variable, which has a default value of 1MB. You may also need to increase the maximum packet size on the client end. More information on setting the packet size is given in &lt;a title="A.1.2.9. Packet too large" href="http://dev.mysql.com/doc/refman/4.1/en/packet-too-large.html"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;Section A.1.2.9, “&lt;code&gt;Packet too large&lt;/code&gt;”&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;. 
&lt;p&gt;An &lt;code&gt;INSERT&lt;/code&gt; or &lt;code&gt;REPLACE&lt;/code&gt; statement that inserts a great many rows can also cause these sorts of errors. Either one of these statements sends a single request to the server irrespective of the number of rows to be inserted; thus, you can often avoid the error by reducing the number of rows sent per &lt;code&gt;INSERT&lt;/code&gt; or &lt;code&gt;REPLACE&lt;/code&gt;. 
&lt;li&gt;
&lt;p&gt;You also get a lost connection if you are sending a packet 16MB or larger if your client is older than 4.0.8 and your server is 4.0.8 and above, or the other way around. 
&lt;li&gt;
&lt;p&gt;It is also possible to see this error if hostname lookups fail (for example, if the DNS server on which your server or network relies goes down). This is because MySQL is dependent on the host system for name resolution, but has no way of knowing whether it is working — from MySQL's point of view the problem is indistinguishable from any other network timeout. 
&lt;p&gt;You may also see the &lt;code&gt;MySQL server has gone away&lt;/code&gt; error if MySQL is started with the &lt;code&gt;--skip-networking&lt;/code&gt; option. 
&lt;p&gt;Another networking issue that can cause this error occurs if the MySQL port (default 3306) is blocked by your firewall, thus preventing any connections at all to the MySQL server. 
&lt;li&gt;
&lt;p&gt;You can also encounter this error with applications that fork child processes, all of which try to use the same connection to the MySQL server. This can be avoided by using a separate connection for each child process. 
&lt;li&gt;
&lt;p&gt;You have encountered a bug where the server died while executing the query. &lt;/ul&gt;&lt;/div&gt;
&lt;p&gt;
&lt;p&gt;&lt;br&gt;
&lt;p&gt;据此分析，可能原因有3：
&lt;p&gt;1，Mysql服务端与客户端版本不匹配。
&lt;p&gt;2，Mysql服务端配置有缺陷或者优化不足
&lt;p&gt;3，需要改进程序脚本
&lt;p&gt;通过更换多个服务端与客户端版本，发现只能部分减少报错，并不能完全解决。排除1。
&lt;p&gt;对服务端进行了彻底的优化，也未能达到理想效果。在timeout的取值设置上，从经验值的10，到PHP默认的60，进行了多次尝试。而Mysql官方默认值(8小时)明显是不可能的。从而对2也进行了排除。(更多优化的经验分享，将在以后整理提供)
&lt;p&gt;针对3对程序代码进行分析，发现程序中大量应用了类似如下的代码(为便于理解，用原始api描述)：
&lt;p&gt;$conn=mysql_connect( ... ... );
&lt;p&gt;... ... ... ...
&lt;p&gt;if(!$conn){ //reconnect
&lt;p&gt;$conn=mysql_connect( ... ... );
&lt;p&gt;}
&lt;p&gt;mysql_query($sql, $conn);
&lt;p&gt;这段代码的含义，与Mysql官方建议的方法思路相符[ If you have a script, you just have to issue the query again for the client to do an automatic reconnection. ]。在实际分析中发现，if(!$conn)并不是可靠的，程序通过了if(!$conn)的检验后，仍然会返回上述错误。
&lt;p&gt;对程序进行了改写：
&lt;p&gt;if(!conn){ // connect ...}
&lt;p&gt;elseif(!mysql_ping($conn)){ // reconnect ... }
&lt;p&gt;mysql_query($sql, $conn);
&lt;p&gt;经实际观测，MySQL server has gone away的报错基本解决。
&lt;p&gt;
&lt;p&gt;BTW： 附带一个关于 reconnect 的疑问，
&lt;p&gt;在php4x+client3x+mysql4x的旧环境下，reconnet的代码：
&lt;p&gt;$conn=mysql_connect(...) 可以正常工作。
&lt;p&gt;但是，在php5x+client4x+mysql4x的新环境下，$conn=mysql_connect(...)返回的$conn有部分情况下不可用。需要书写为：
&lt;p&gt;mysql_close($conn);
&lt;p&gt;$conn=mysql_connect(...);
&lt;p&gt;返回的$conn才可以正常使用。原因未明。未做深入研究，也未见相关讨论。或许mysql官方的BUG汇报中会有吧。
&lt;p&gt;
&lt;p&gt;～～呵呵～～&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/123"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/123&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+MySQL%3a+%e8%af%a1%e5%bc%82%e7%9a%84MySQL+server+has+gone+away%e5%8f%8a%e5%85%b6%e8%a7%a3%e5%86%b3&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><category>None</category><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!253.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!253.entry</guid><pubDate>Tue, 20 Mar 2007 01:29:21 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!253/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!253.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:29:21Z</dcterms:modified></item><item><title>MySQL: 4.X 版本数据库向 5.15 以上迁移</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!252.entry</link><description>&lt;div&gt;
&lt;h3&gt;MySQL: 4.X 版本数据库向 5.15 以上迁移&lt;/h3&gt;&lt;span&gt;jimmy | 15 三月, 2007 13:53&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;会有两个问题：
&lt;p&gt;1，表结构变化
&lt;p&gt;2，权限表及辅助表变化
&lt;p&gt;解决问题1，官方的建议是全部导出，然后在新的库里面导入。
&lt;p&gt;实际操作中，旧表直接搬迁后是可以继续使用的，只是效率和一些新功能可能会受到影响。保持线上服务的同时，运行mysql_repaire，或者是在phpmyadmnin里面修复一下，就可以了。
&lt;p&gt;注意：要先进行备份。升级后的表，如果需要退回到mysql4x版本，是不能够使用的。
&lt;p&gt;解决问题2，如果不升级也是可以继续使用的，但是在日志中会看到：
&lt;p&gt;070315 13:36:35 [ERROR] mysql.user has no `Event_priv` column at position 29&lt;br&gt;070315 13:36:35 [ERROR] SCHEDULER: The system tables are damaged. The scheduler subsystem will be unusable during this run.
&lt;p&gt;同时会导致 &lt;strong&gt;SHOW VARIABLES;&lt;/strong&gt; 命令不可用，无法查看系统变量情况。
&lt;p&gt;官方的解决方案是： mysql/bin/mysql_fix_privilege_tables，但实际操作中发现并不能解决(Beta版的bug?)。手工处理会稍微复杂一些，因为表结构变化，直接导出、导入是不行的。
&lt;p&gt;A，导出user表内容到user.sql
&lt;p&gt;B，用scripts/mysql_install_db生成新结构的表，覆盖旧表。
&lt;p&gt;C，修改user.sql，删除create段，修改INSERT段，将SQL语句补全为：
&lt;p&gt;INSERT INTO `user` (`Host`,`User`,`Password`,`Select_priv`,`Inser ... ...) VALUES (.. ... ...)
&lt;p&gt;D，删除user表内容，将user.sql导入。
&lt;p&gt;E，重启数据库。
&lt;p&gt;Done。
&lt;p&gt;
&lt;p&gt;～～呵呵～～&lt;br&gt;&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/122"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/122&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+MySQL%3a+4.X+%e7%89%88%e6%9c%ac%e6%95%b0%e6%8d%ae%e5%ba%93%e5%90%91+5.15+%e4%bb%a5%e4%b8%8a%e8%bf%81%e7%a7%bb&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!252.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!252.entry</guid><pubDate>Tue, 20 Mar 2007 01:28:17 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!252/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!252.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:28:17Z</dcterms:modified></item><item><title>MySQL: Linux机上运行多个版本的MySQL</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!251.entry</link><description>&lt;div&gt;
&lt;h3&gt;MySQL: Linux机上运行多个版本的MySQL&lt;/h3&gt;&lt;span&gt;jimmy | 14 三月, 2007 10:15&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;在同一台服务器上部署多个MySQL服务，可以有效提高机器利用率。而且，将不同内容分属不同服务上，也相对更安全些。
&lt;p&gt;MySQL提供了mysqld_multi，但实际应用中没有人用它。弊端：
&lt;p&gt;1，暂停、重启，会导致所有服务都停下来。
&lt;p&gt;2，配置文件冗长，拆分、迁移时麻烦。
&lt;p&gt;业内比较常用的方法是，将数据库数据文件和配置文件，以及开启关闭脚本，共同放在一个目录下。启动服务时，作为一个单独的服务；关闭时对其他服务没有影响。搬迁时，只要将这个目录迁移到目标机器上就OK了。
&lt;p&gt;一个典型的例子：
&lt;p&gt;&lt;img style="" src="http://www.jimmydong.com/blog/resserver.php?blogId=1&amp;amp;resource=snap082.png"&gt;
&lt;p&gt;&lt;br&gt;
&lt;p&gt;&lt;font size=2&gt;10.10.82.83 [server2]$ cat start.sh &lt;br&gt;#!/bin/sh&lt;br&gt;rundir=&amp;quot;/opt/server2&amp;quot;;&lt;br&gt;echo $rundir;&lt;br&gt;/usr/local/mysql/bin/mysqld_safe --defaults-file=&amp;quot;$rundir&amp;quot;/my.cnf --pid-file=&amp;quot;$rundir&amp;quot;/mysql.pid --datadir=&amp;quot;$rundir&amp;quot;/var --socket=&amp;quot;$rundir&amp;quot;/mysql.sock --log-error=&amp;quot;$rundir&amp;quot;/err.log --log-slow-queries=&amp;quot;$rundir&amp;quot;/slow_query.log&amp;amp;&lt;/font&gt;
&lt;p&gt;上例中使用的MySQL是按照官方建议安装在/usr/local/mysql下的。
&lt;p&gt;有时候需要在同一台服务器上使用多个不同版本，比如，测试新版本等。按照以上逻辑，将新MySQLD安装在 /usr/local/mysql-new下，修改 start.sh 为 /usr/local/mysql-new/bin/mysqld_safe。数据库可以正常启动，但是，观察发现并不是新版本。原因何在？
&lt;p&gt;官方的解释是：需要下载源代码版本，编译时指定运行目录。其实并非必须如此。
&lt;p&gt;研究mysqld_safe文件，发现其逻辑为：
&lt;p&gt;A，从命令行取配置参数
&lt;p&gt;B，从配置文件取配置参数
&lt;p&gt;C，对于mysqld的目录（basedir）和数据文件目录（datadir），如果以上都没有在配置中指定，则先检查当前目录是否可用，否则设置/usr/local/mysql为默认。
&lt;p&gt;所以，虽然使用的是mysql-new下的mysqld_safe，但运行的还是/usr/local/mysql/bin/mysqld，也就是旧版本。需要相应修改启动脚本，或者是配置文件：
&lt;p&gt;&lt;font size=2&gt;#!/bin/sh&lt;br&gt;rundir=&amp;quot;/opt/server0&amp;quot;;&lt;br&gt;echo $rundir;&lt;br&gt;/usr/local/mysql-new/bin/mysqld_safe --defaults-file=&amp;quot;$rundir&amp;quot;/my.cnf --ledir=/usr/local/mysql-new/bin --basedir=/usr/local/mysql-new --pid-file=&amp;quot;$rundir&amp;quot;/mysql.pid --datadir=&amp;quot;$rundir&amp;quot;/var --socket=&amp;quot;$rundir&amp;quot;/mysql.sock --log-error=&amp;quot;$rundir&amp;quot;/err.log --log-slow-queries=&amp;quot;$rundir&amp;quot;/slow_query.log&amp;amp;&lt;/font&gt;
&lt;p&gt;这样就可以在同一台机器上同时运行多个版本的Mysql了。
&lt;p&gt;&lt;br&gt;～～呵呵～～&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/121"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/121&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+MySQL%3a+Linux%e6%9c%ba%e4%b8%8a%e8%bf%90%e8%a1%8c%e5%a4%9a%e4%b8%aa%e7%89%88%e6%9c%ac%e7%9a%84MySQL&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!251.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!251.entry</guid><pubDate>Tue, 20 Mar 2007 01:27:36 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!251/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!251.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:27:36Z</dcterms:modified></item><item><title>MySQL: time_format格式</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!250.entry</link><description>&lt;div&gt;
&lt;h3&gt;MySQL: time_format格式&lt;/h3&gt;&lt;span&gt;jimmy | 13 三月, 2007 14:51&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;&lt;span&gt;TIME_FORMAT(&lt;i&gt;time&lt;/i&gt;,&lt;i&gt;format&lt;/i&gt;) &lt;/span&gt;
&lt;p&gt;eg： time_format(the_time, '%Y-%m-%d %T')
&lt;table cellpadding=0 width=531 border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;说明符&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;strong&gt;&lt;span&gt;说明&lt;/span&gt;&lt;/strong&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%a&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;工作日的缩写名称 (Sun..Sat)
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%b&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;月份的缩写名称&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;Jan&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;Dec&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%c&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;月份，数字形式&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;0&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;12&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%D&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;带有英语后缀的该月日期&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;0th&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;1st&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;2nd&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;3rd&lt;/span&gt;&lt;span&gt;, ...)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;%d&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;该月日期&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;31&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%e&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;该月日期&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;0&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;31&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%f&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;微秒&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;000000&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;999999&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;%H&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;小时&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;23&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%h&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;小时&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;01&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;12&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%I&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;小时&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;01&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;12&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;%i&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;分钟&lt;/span&gt;&lt;span&gt;,&lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;59&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%j&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;一年中的天数&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;001&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;366&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%k&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;小时&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;0&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;23&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%l&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;小时&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;1&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;12&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%M&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;月份名称&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;January&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;December&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;%m&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;月份&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;12&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%p&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;上午（&lt;span&gt;AM&lt;/span&gt;）或下午（&lt;/span&gt;&lt;span&gt; &lt;/span&gt;&lt;span&gt;&lt;span&gt;PM&lt;/span&gt;&lt;span&gt;）&lt;/span&gt;&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%r&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;时间&lt;/span&gt;&lt;span&gt; , 12&lt;/span&gt;&lt;span&gt;小时制&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;小时&lt;span&gt;hh:&lt;/span&gt;分钟&lt;span&gt;mm:&lt;/span&gt;秒数&lt;span&gt;ss&lt;/span&gt;&lt;/span&gt;&lt;span&gt; &lt;/span&gt;&lt;span&gt;后加&lt;/span&gt;&lt;span&gt; &lt;/span&gt;&lt;span&gt;AM&lt;/span&gt;&lt;span&gt;或&lt;/span&gt;&lt;span&gt;PM&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%S&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;秒&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;59&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;%s&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;秒&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;59&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%T&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;时间&lt;/span&gt;&lt;span&gt; , 24&lt;/span&gt;&lt;span&gt;小时制&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;小时&lt;span&gt;hh:&lt;/span&gt;分钟&lt;span&gt;mm:&lt;/span&gt;秒数&lt;span&gt;ss&lt;/span&gt;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%U&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;周&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;53&lt;/span&gt;&lt;span&gt;), &lt;/span&gt;&lt;span&gt;其中周日为每周的第一天&lt;/span&gt;&lt;span&gt; &lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%u&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;周&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;00&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;53&lt;/span&gt;&lt;span&gt;), &lt;/span&gt;&lt;span&gt;其中周一为每周的第一天&lt;/span&gt;&lt;span&gt; &lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%V&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;周&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;01&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;53&lt;/span&gt;&lt;span&gt;), &lt;/span&gt;&lt;span&gt;其中周日为每周的第一天&lt;/span&gt;&lt;span&gt; ; &lt;/span&gt;&lt;span&gt;和&lt;/span&gt;&lt;span&gt; &lt;/span&gt;&lt;span&gt;&lt;span&gt;%X&lt;/span&gt;&lt;span&gt;同时使用&lt;/span&gt;&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%v&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;周&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;01&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;53&lt;/span&gt;&lt;span&gt;), &lt;/span&gt;&lt;span&gt;其中周一为每周的第一天&lt;/span&gt;&lt;span&gt; ; &lt;/span&gt;&lt;span&gt;和&lt;/span&gt;&lt;span&gt; &lt;/span&gt;&lt;span&gt;&lt;span&gt;%x&lt;/span&gt;&lt;span&gt;同时使用&lt;/span&gt;&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%W&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;工作日名称&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;周日&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;周六&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%w&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;一周中的每日&lt;/span&gt;&lt;span&gt; (&lt;/span&gt;&lt;span&gt;0&lt;/span&gt;&lt;span&gt;=&lt;/span&gt;&lt;span&gt;周日&lt;/span&gt;&lt;span&gt;..&lt;/span&gt;&lt;span&gt;6&lt;/span&gt;&lt;span&gt;=&lt;/span&gt;&lt;span&gt;周六&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%X&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;该周的年份，其中周日为每周的第一天&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt;,4&lt;/span&gt;&lt;span&gt;位数&lt;/span&gt;&lt;span&gt;;&lt;/span&gt;&lt;span&gt;和&lt;/span&gt;&lt;span&gt;&lt;span&gt;%V&lt;/span&gt;&lt;span&gt;同时使用&lt;/span&gt;&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%x&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;该周的年份，其中周一为每周的第一天&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt;,4&lt;/span&gt;&lt;span&gt;位数&lt;/span&gt;&lt;span&gt;;&lt;/span&gt;&lt;span&gt;和&lt;/span&gt;&lt;span&gt;&lt;span&gt;%v&lt;/span&gt;&lt;span&gt;同时使用&lt;/span&gt;&lt;/span&gt;&lt;span&gt; &lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;%Y&lt;/span&gt;&lt;/b&gt;
&lt;td&gt;
&lt;p&gt;&lt;b&gt;&lt;span&gt;年份&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt;,4&lt;/span&gt;&lt;span&gt;位数&lt;/span&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%y&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;年份&lt;/span&gt;&lt;span&gt;, &lt;/span&gt;&lt;span&gt;数字形式&lt;/span&gt;&lt;span&gt; (2&lt;/span&gt;&lt;span&gt;位数&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;
&lt;tr&gt;
&lt;td width=59&gt;
&lt;p&gt;&lt;span&gt;%%&lt;/span&gt;
&lt;td&gt;
&lt;p&gt;&lt;span&gt;‘&lt;/span&gt;&lt;span&gt;%&lt;/span&gt;&lt;span&gt;’文字字符&lt;/span&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;
&lt;p&gt;～～呵呵～～&lt;br&gt;&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/120"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/120&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+MySQL%3a+time_format%e6%a0%bc%e5%bc%8f&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!250.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!250.entry</guid><pubDate>Tue, 20 Mar 2007 01:26:47 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!250/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!250.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:26:47Z</dcterms:modified></item><item><title>转： apache2 MPM的选择与配置</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!249.entry</link><description>&lt;div&gt;
&lt;h3&gt;转： apache2 MPM的选择与配置&lt;/h3&gt;&lt;span&gt;jimmy | 06 三月, 2007 20:27&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;　谈到Apache，大多数系统管理员对其稳定版1.3印象颇深。虽然Apache 2.0的系列开发版早已由Alpha、Beta发展到现在的GA（General Availability）版，但是一些人潜意识里还认为开发版并非可用于生产环境的稳定版本。尤其是1.3版的API与2.0版不兼容，使得大量模块必须要重写才能在2.0版上使用。Apache 1.3和2.0之间的内部变化的确较大，用Apache创始人Brian Behlendorf自己的话来说：“这个版本包括了数百个新的特性，所以这个产品应该具有3.1或8i这样的产品编号，而不是2.0。”Apache 2.0中加入了很多的核心改进和新功能，如Unix线程、多协议支持、新的构建系统、对非Unix平台的更佳支持、IPv6支持、新的Apache API、过滤器、多语言错误响应、原生的Windows NT Unicode支持、更简单化的配置，以及升级的正则表达式库等。它当然还包括对许多模块的重要改进，同时也加入了一些新的模块。&lt;br&gt;
&lt;div&gt;　　为了使Apache更加平滑地从1.3版升级到2.0版，Apache开发团队做了很多工作。目前很多重要的模块已经可以很好地支持2.0版，如 PHP、FastCGI、Mod_perl、Mod_python等。在httpd.conf的指令配置语法上，目前的2.0版（2.0.45）与1.3 版的兼容性已做得相当好。比如，以前的2.0版如果要使用PHP，一般用过滤器实现；现在的PHP官方文档中已经使用1.3版中的LoadModule语句做为加载PHP的推荐方式。只要略微了解一下Apache 2.0的新特性，从1.3版升级到2.0版将是一件非常容易的事情。使用Apache 2.0是大势所趋，因为Apache的开发团队已经把开发重心转移到2.0版上。1.3版自2002年10月发布了1.3.27后一直没有新版本推出，而 2.0版在与1.3.27同时发布2.0.43后，在今年1月发布了2.0.44，并于今年3月末发布了2.0.45，并包含了很多改进和修正。 &lt;br&gt;&lt;br&gt;　　&lt;b&gt;MPM的引入带来性能改善&lt;/b&gt; &lt;br&gt;&lt;br&gt;　　Apache 2.0在性能上的改善最吸引人。在支持POSIX线程的Unix系统上，Apache可以通过不同的MPM运行在一种多进程与多线程相混合的模式下，增强部分配置的可扩充性能。相比于Apache 1.3，2.0版本做了大量的优化来提升处理能力和可伸缩性，并且大多数改进在默认状态下即可生效。但是在编译和运行时刻，2.0也有许多可以显著提高性能的选择。本文不想叙述那些以功能换取速度的指令，如HostnameLookups等，而只是说明在2.0中影响性能的最核心特性：MPM（Multi -Processing Modules，多道处理模块）的基本工作原理和配置指令。 &lt;br&gt;&lt;br&gt;　　毫不夸张地说，MPM的引入是Apache 2.0最重要的变化。大家知道，Apache是基于模块化的设计，而Apache 2.0更扩展了模块化设计到Web服务器的最基本功能。服务器装载了一种多道处理模块，负责绑定本机网络端口、接受请求，并调度子进程来处理请求。扩展模块化设计有两个重要好处： &lt;br&gt;&lt;br&gt;　　◆ Apache可以更简洁、有效地支持多种操作系统； &lt;br&gt;&lt;br&gt;　　◆ 服务器可以按站点的特殊需要进行自定制。 &lt;br&gt;&lt;br&gt;　　在用户级，MPM看起来和其它Apache模块非常类似。主要区别是在任意时刻只能有一种MPM被装载到服务器中。 &lt;br&gt;&lt;br&gt;　　&lt;b&gt;指定MPM的方法&lt;/b&gt; &lt;br&gt;&lt;br&gt;　　下面以Red Hat Linux 9为平台，说明在Apache 2.0中如何指定MPM (Apache采用2.0.45)。先解压缩源代码包httpd-2.0.45.tar.gz，生成httpd-2.0.45目录（Apache 1.3源代码包的命名规则是apache_1.3.NN.tar.gz，而2.0版则是httpd-2.0.NN.tar.gz，其中NN是次版本号）。 &lt;br&gt;&lt;br&gt;　　进入httpd-2.0.45目录，运行以下代码： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;$ ./configure --help|grep mpm&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　显示如下： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;--with-mpm=MPM&lt;br&gt;Choose the process model for Apache to use.&lt;br&gt;MPM={beos|worker|prefork|mpmt_os2| perchild|leader|threadpool}&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　上述操作用来选择要使用的进程模型，即哪种MPM模块。Beos、mpmt_os2分别是BeOS和OS/2上缺省的MPM，perchild主要设计目的是以不同的用户和组的身份来运行不同的子进程。这在运行多个需要CGI的虚拟主机时特别有用，会比1.3版中的SuExec机制做得更好。 leader和threadpool都是基于worker的变体，还处于实验性阶段，某些情况下并不会按照预期设想的那样工作，所以Apache官方也并不推荐使用。因此，我们主要阐述prefork和worker这两种和性能关系最大的产品级MPM ( 有关其它的MPM详细说明，请参见Apache官方文档：http://httpd.apache.org/docs-2.0/mod/)。 &lt;br&gt;&lt;br&gt;　　&lt;b&gt;prefork的工作原理及配置&lt;/b&gt; &lt;br&gt;&lt;br&gt;　　如果不用“--with-mpm”显式指定某种MPM，prefork就是Unix平台上缺省的MPM。它所采用的预派生子进程方式也是Apache 1.3中采用的模式。prefork本身并没有使用到线程，2.0版使用它是为了与1.3版保持兼容性；另一方面，prefork用单独的子进程来处理不同的请求，进程之间是彼此独立的，这也使其成为最稳定的MPM之一。 &lt;br&gt;&lt;br&gt;　　若使用prefork，在make编译和make install安装后，使用“httpd -l”来确定当前使用的MPM，应该会看到prefork.c（如果看到worker.c说明使用的是worker MPM，依此类推）。再查看缺省生成的httpd.conf配置文件，里面包含如下配置段： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;&lt;br&gt;StartServers          5&lt;br&gt;MinSpareServers      5&lt;br&gt;MaxSpareServers     10&lt;br&gt;MaxClients         150&lt;br&gt;MaxRequestsPerChild  0&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　prefork的工作原理是，控制进程在最初建立“StartServers”个子进程后，为了满足MinSpareServers设置的需要创建一个进程，等待一秒钟，继续创建两个，再等待一秒钟，继续创建四个……如此按指数级增加创建的进程数，最多达到每秒32个，直到满足 MinSpareServers设置的值为止。这就是预派生（prefork）的由来。这种模式可以不必在请求到来时再产生新的进程，从而减小了系统开销以增加性能。 &lt;br&gt;&lt;br&gt;　　MaxSpareServers设置了最大的空闲进程数，如果空闲进程数大于这个值，Apache会自动kill掉一些多余进程。这个值不要设得过大，但如果设的值比MinSpareServers小，Apache会自动把其调整为MinSpareServers+ 1。如果站点负载较大，可考虑同时加大MinSpareServers和MaxSpareServers。 &lt;br&gt;&lt;br&gt;　　 MaxRequestsPerChild设置的是每个子进程可处理的请求数。每个子进程在处理了“MaxRequestsPerChild”个请求后将自动销毁。0意味着无限，即子进程永不销毁。虽然缺省设为0可以使每个子进程处理更多的请求，但如果设成非零值也有两点重要的好处： &lt;br&gt;&lt;br&gt;　　◆ 可防止意外的内存泄漏； &lt;br&gt;&lt;br&gt;　　◆ 在服务器负载下降的时侯会自动减少子进程数。 &lt;br&gt;&lt;br&gt;　　因此，可根据服务器的负载来调整这个值。笔者认为10000左右比较合适。 &lt;br&gt;&lt;br&gt;　　MaxClients是这些指令中最为重要的一个，设定的是Apache可以同时处理的请求，是对Apache性能影响最大的参数。其缺省值150是远远不够的，如果请求总数已达到这个值（可通过ps -ef|grep http|wc -l来确认），那么后面的请求就要排队，直到某个已处理请求完毕。这就是系统资源还剩下很多而HTTP访问却很慢的主要原因。系统管理员可以根据硬件配置和负载情况来动态调整这个值。虽然理论上这个值越大，可以处理的请求就越多，但Apache默认的限制不能大于256。如果把这个值设为大于256，那么 Apache将无法起动。事实上，256对于负载稍重的站点也是不够的。在Apache 1.3中，这是个硬限制。如果要加大这个值，必须在“configure”前手工修改的源代码树下的src/include/httpd.h中查找 256，就会发现“#define HARD_SERVER_LIMIT 256”这行。把256改为要增大的值（如4000），然后重新编译Apache即可。在Apache 2.0中新加入了ServerLimit指令，使得无须重编译Apache就可以加大MaxClients。下面是笔者的prefork配置段： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;&lt;br&gt;StartServers         10&lt;br&gt;MinSpareServers      10&lt;br&gt;MaxSpareServers     15&lt;br&gt;ServerLimit       2000&lt;br&gt;MaxClients         1000&lt;br&gt;MaxRequestsPerChild  10000&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　上述配置中，ServerLimit的最大值是20000，对于大多数站点已经足够。如果一定要再加大这个数值，对位于源代码树下server/mpm/prefork/prefork.c中以下两行做相应修改即可： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;#define DEFAULT_SERVER_LIMIT 256&lt;br&gt;#define MAX_SERVER_LIMIT 20000&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　&lt;b&gt;worker的工作原理及配置&lt;/b&gt; &lt;br&gt;&lt;br&gt;　　相对于prefork，worker是2.0 版中全新的支持多线程和多进程混合模型的MPM。由于使用线程来处理，所以可以处理相对海量的请求，而系统资源的开销要小于基于进程的服务器。但是， worker也使用了多进程，每个进程又生成多个线程，以获得基于进程服务器的稳定性。这种MPM的工作方式将是Apache 2.0的发展趋势。 &lt;br&gt;&lt;br&gt;　　在configure -with-mpm=worker后，进行make编译、make install安装。在缺省生成的httpd.conf中有以下配置段： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;&lt;br&gt;StartServers         2&lt;br&gt;MaxClients         150&lt;br&gt;MinSpareThreads     25&lt;br&gt;MaxSpareThreads     75&lt;br&gt;ThreadsPerChild     25&lt;br&gt;MaxRequestsPerChild  0&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　worker的工作原理是，由主控制进程生成“StartServers”个子进程，每个子进程中包含固定的ThreadsPerChild线程数，各个线程独立地处理请求。同样，为了不在请求到来时再生成线程，MinSpareThreads和MaxSpareThreads设置了最少和最多的空闲线程数；而MaxClients设置了所有子进程中的线程总数。如果现有子进程中的线程总数不能满足负载，控制进程将派生新的子进程。 &lt;br&gt;&lt;br&gt;　　MinSpareThreads和MaxSpareThreads的最大缺省值分别是75和250。这两个参数对Apache的性能影响并不大，可以按照实际情况相应调节。 &lt;br&gt;&lt;br&gt;　　ThreadsPerChild是worker MPM中与性能相关最密切的指令。ThreadsPerChild的最大缺省值是64，如果负载较大，64也是不够的。这时要显式使用 ThreadLimit指令，它的最大缺省值是20000。上述两个值位于源码树server/mpm/worker/worker.c中的以下两行： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;#define DEFAULT_THREAD_LIMIT 64&lt;br&gt;#define MAX_THREAD_LIMIT 20000&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　这两行对应着ThreadsPerChild和ThreadLimit的限制数。最好在configure之前就把64改成所希望的值。注意，不要把这两个值设得太高，超过系统的处理能力，从而因Apache不起动使系统很不稳定。 &lt;br&gt;&lt;br&gt;　　Worker模式下所能同时处理的请求总数是由子进程总数乘以ThreadsPerChild值决定的，应该大于等于MaxClients。如果负载很大，现有的子进程数不能满足时，控制进程会派生新的子进程。默认最大的子进程总数是16，加大时也需要显式声明ServerLimit（最大值是 20000）。这两个值位于源码树server/mpm/worker/worker.c中的以下两行： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;#define DEFAULT_SERVER_LIMIT 16&lt;br&gt;#define MAX_SERVER_LIMIT 20000&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　需要注意的是，如果显式声明了ServerLimit，那么它乘以ThreadsPerChild的值必须大于等于MaxClients，而且 MaxClients必须是ThreadsPerChild的整数倍，否则Apache将会自动调节到一个相应值（可能是个非期望值）。下面是笔者的 worker配置段： &lt;br&gt;&lt;br&gt;
&lt;table cellspacing=0 bordercolordark="#ffffff" cellpadding=2 width=550 align=center bordercolorlight=black border=1&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td bgcolor="#e6e6e6"&gt;&lt;pre&gt;&lt;br&gt;StartServers         3&lt;br&gt;MaxClients         2000&lt;br&gt;ServerLimit        25&lt;br&gt;MinSpareThreads     50&lt;br&gt;MaxSpareThreads     200&lt;br&gt;ThreadLimit        200&lt;br&gt;ThreadsPerChild     100&lt;br&gt;MaxRequestsPerChild  0&lt;/pre&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;br&gt;　　通过上面的叙述，可以了解到Apache 2.0中prefork和worker这两个重要MPM的工作原理，并可根据实际情况来配置Apache相关的核心参数，以获得最大的性能和稳定性。&lt;/div&gt;&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/118"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/118&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+%e8%bd%ac%ef%bc%9a+apache2+MPM%e7%9a%84%e9%80%89%e6%8b%a9%e4%b8%8e%e9%85%8d%e7%bd%ae&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!249.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!249.entry</guid><pubDate>Tue, 20 Mar 2007 01:25:57 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!249/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!249.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:25:57Z</dcterms:modified></item><item><title>MySQL5的分区研究</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!248.entry</link><description>&lt;div&gt;
&lt;h3&gt;MySQL5的分区研究&lt;/h3&gt;&lt;span&gt;jimmy | 06 二月, 2007 11:14&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;MySQL5.1提供的分区技术，令人对其充满希望。
&lt;p&gt;根据官方文档，分区技术能够极大的帮助DBA人员。支持的分区模式包括：
&lt;p&gt;Range
&lt;p&gt;List
&lt;p&gt;Hash
&lt;p&gt;Key
&lt;p&gt;----
&lt;p&gt;安装配置记录：
&lt;p&gt;wget &lt;a href="http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.16-beta-linux-i686-icc-glibc23.tar.gz/from/http://mysql.cdpa.nsysu.edu.tw/&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;tar"&gt;&lt;font color="#0000ff"&gt;&lt;u&gt;http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.16-beta-linux-i686-icc-glibc23.tar.gz/from/http://mysql.cdpa.nsysu.edu.tw/&lt;/u&gt;&lt;/font&gt;&lt;/a&gt;
&lt;p&gt;&lt;a href="http://dev.mysql.com/get/Downloads/MySQL-5.1/mysql-5.1.16-beta-linux-i686-icc-glibc23.tar.gz/from/http://mysql.cdpa.nsysu.edu.tw/&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;tar"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;tar&lt;/font&gt;&lt;/u&gt;&lt;/a&gt; -xzvf mysql-5.1.16-beta-linux-i686-icc-glibc23.tar.gz
&lt;p&gt;mv mysql-5.1.16-beta-linux-i686-icc-glibc23 /usr/local/mysql-5.1
&lt;p&gt;修改启动脚本，启动
&lt;p&gt;
&lt;p&gt;&lt;br&gt;
&lt;p&gt;检查当前版本是否支持分区：
&lt;p&gt;&lt;span&gt;&lt;span&gt;&lt;b&gt;SHOW VARIABLES LIKE '%partition%';&lt;/b&gt;&lt;/span&gt;&lt;/span&gt;
&lt;p&gt;测试带分区的表：(From 手册)
&lt;p&gt;&lt;font size=2&gt;CREATE TABLE tr (id INT, name VARCHAR(50), purchased DATE)&lt;br&gt;PARTITION BY RANGE(YEAR(purchased))&lt;br&gt;(&lt;br&gt;PARTITION p0 VALUES LESS THAN (1990),&lt;br&gt;PARTITION p1 VALUES LESS THAN (1995),&lt;br&gt;PARTITION p2 VALUES LESS THAN (2000),&lt;br&gt;PARTITION p3 VALUES LESS THAN (2005)&lt;br&gt;);&lt;br&gt;&lt;br&gt;&lt;br&gt;INSERT INTO tr VALUES&lt;br&gt;(1, 'desk organiser', '2003-10-15'),&lt;br&gt;(2, 'CD player', '1993-11-05'),&lt;br&gt;(3, 'TV set', '1996-03-10'),&lt;br&gt;(4, 'bookcase', '1982-01-10'),&lt;br&gt;(5, 'exercise bike', '2004-05-09'),&lt;br&gt;(6, 'sofa', '1987-06-05'),&lt;br&gt;(7, 'popcorn maker', '2001-11-22'),&lt;br&gt;(8, 'aquarium', '1992-08-04'),&lt;br&gt;(9, 'study desk', '1984-09-16'),&lt;br&gt;(10, 'lava lamp', '1998-12-25');&lt;/font&gt;
&lt;p&gt;从服务器上可以看到文件结构为：
&lt;p&gt;&lt;font size=2&gt;10.10.82.83 [testuser]$ l&lt;br&gt;total 404M&lt;br&gt;-rw-rw---- 1 mysql mysql 8.5K 2007-03-14 15:26:29 tr.frm&lt;br&gt;-rw-rw---- 1 mysql mysql 32 2007-03-14 15:26:29 tr.par&lt;br&gt;-rw-rw---- 1 mysql mysql 68 2007-03-14 15:26:48 tr#P#p0.MYD&lt;br&gt;-rw-rw---- 1 mysql mysql 1.0K 2007-03-14 15:26:48 tr#P#p0.MYI&lt;br&gt;-rw-rw---- 1 mysql mysql 48 2007-03-14 15:26:48 tr#P#p1.MYD&lt;br&gt;-rw-rw---- 1 mysql mysql 1.0K 2007-03-14 15:26:48 tr#P#p1.MYI&lt;br&gt;-rw-rw---- 1 mysql mysql 44 2007-03-14 15:26:48 tr#P#p2.MYD&lt;br&gt;-rw-rw---- 1 mysql mysql 1.0K 2007-03-14 15:26:48 tr#P#p2.MYI&lt;br&gt;-rw-rw---- 1 mysql mysql 84 2007-03-14 15:26:48 tr#P#p3.MYD&lt;br&gt;-rw-rw---- 1 mysql mysql 1.0K 2007-03-14 15:26:48 tr#P#p3.MYI&lt;/font&gt;
&lt;p&gt;说明创建分区成功。
&lt;p&gt;测试分区管理，删除：
&lt;p&gt;&lt;span&gt;&lt;span&gt;&lt;b&gt;ALTER TABLE tr DROP PARTITION p2;&lt;/b&gt;&lt;/span&gt;&lt;/span&gt;
&lt;p&gt;添加：&lt;pre&gt;&lt;span&gt;&lt;span&gt;&lt;b&gt;ALTER TABLE tr ADD PARTITION (PARTITION p2 VALUES LESS THAN (2000));&lt;/b&gt;&lt;/span&gt;&lt;/span&gt;&lt;/pre&gt;
&lt;p&gt;注意：
&lt;p&gt;1，删除分区后，分区内的数据也不可恢复的删除了。
&lt;p&gt;2，只有range和list分区可以进行无数据影响的添加操作。其他种类的分区，不要进行分区管理。或者是，先把数据全导出，改变分区结构后再导入。
&lt;p&gt;3，作为分区依据的列值是可以修改的，修改后会转移到对应分区中。（这点很有意义哟～）
&lt;p&gt;下面是实战：
&lt;p&gt;CREATE TABLE `user` (&lt;br&gt;`id` int(11) not null auto_increment,&lt;br&gt;`cn` varchar(22) not null default '',&lt;br&gt;`nickname` varchar(32) not null default '',&lt;br&gt;`genderid` tinyint(1) unsigned default null,&lt;br&gt;`artnum` int(8) unsigned default '0',&lt;br&gt;`elitenum` int(8) unsigned default '0',&lt;br&gt;`commnum` int(11) not null default '0',&lt;br&gt;`delnum` int(8) unsigned default '0',&lt;br&gt;`loginnum` int(8) unsigned default '1',&lt;br&gt;`linetime` int(8) unsigned default '0',&lt;br&gt;`lastdate` datetime default null,&lt;br&gt;`power` int(10) not null default '0',&lt;br&gt;`score` int(8) default '0',&lt;br&gt;`inputdate` datetime default null,&lt;br&gt;`finallydate` datetime default null,&lt;br&gt;`ad3` tinyint(4) not null default '0',&lt;br&gt;primary key (`id`),&lt;br&gt;key `nickname` (`nickname`),&lt;br&gt;key `finallydate` (`finallydate`)&lt;br&gt;) ENGINE=MyISAM DEFAULT CHARSET=gb2312 AUTO_INCREMENT=4589157&lt;br&gt;PARTITION BY RANGE(id)&lt;br&gt;(&lt;br&gt;PARTITION p5 VALUES LESS THAN (5000000),&lt;br&gt;PARTITION p6 VALUES LESS THAN (6000000),&lt;br&gt;PARTITION p7 VALUES LESS THAN (7000000),&lt;br&gt;PARTITION p8 VALUES LESS THAN (8000000),&lt;br&gt;PARTITION p9 VALUES LESS THAN (9000000),&lt;br&gt;PARTITION p10 VALUES LESS THAN (10000000),&lt;br&gt;PARTITION p11 VALUES LESS THAN (11000000),&lt;br&gt;PARTITION p12 VALUES LESS THAN (12000000),&lt;br&gt;PARTITION p13 VALUES LESS THAN (13000000),&lt;br&gt;PARTITION p14 VALUES LESS THAN (14000000),&lt;br&gt;PARTITION p15 VALUES LESS THAN (15000000),&lt;br&gt;PARTITION p16 VALUES LESS THAN (16000000),&lt;br&gt;PARTITION p0 VALUES LESS THAN MAXVALUE&lt;br&gt;);
&lt;p&gt;关入400万数据，性能对比：
&lt;p&gt;（待补充）
&lt;p&gt;
&lt;p&gt;方案二，使用Key进行划分
&lt;p&gt;create table `user2` (&lt;br&gt;`cn` varchar(22) not null default '',&lt;br&gt;`nickname` varchar(32) not null default '',&lt;br&gt;`genderid` tinyint(1) unsigned default null,&lt;br&gt;`artnum` int(8) unsigned default '0',&lt;br&gt;`elitenum` int(8) unsigned default '0',&lt;br&gt;`commnum` int(11) not null default '0',&lt;br&gt;`delnum` int(8) unsigned default '0',&lt;br&gt;`loginnum` int(8) unsigned default '1',&lt;br&gt;`linetime` int(8) unsigned default '0',&lt;br&gt;`lastdate` datetime default null,&lt;br&gt;`power` int(10) not null default '0',&lt;br&gt;`score` int(8) default '0',&lt;br&gt;`inputdate` datetime default null,&lt;br&gt;`finallydate` datetime default null,&lt;br&gt;`ad3` tinyint(4) not null default '0',&lt;br&gt;primary key (`cn`),&lt;br&gt;key `nickname` (`nickname`),&lt;br&gt;key `finallydate` (`finallydate`)&lt;br&gt;) engine=myisam default charset=gb2312&lt;br&gt;partition by key(cn)&lt;br&gt;partitions 3;&lt;br&gt;&lt;br&gt;增加分区数：ALTER TABLE user2 ADD PARTITION PARTITIONS 10;&lt;br&gt;&lt;br&gt;减少分区数：ALTER TABLE user2 COALESCE PARTITION 6;
&lt;p&gt;增加和减少分区时，数据并不丢失。
&lt;p&gt;
&lt;p&gt;一个不很方便的地方在于，当划分分区时，有unique的列时可能会拒绝操作。
&lt;p&gt;另外，关于性能方面。range,list划分会对提高性能有帮助，但是作用多大，还是跟具体应用有关的。可以肯定的是，不会比我们传统上用程序逻辑将数据分散到多个表的方法效率更高，只是更方便而已。对于hash,key的划分，需要消耗大量计算时间，如果设计不当，可能还会造成性能的下降。所以，这也是我没有立即写性能对比数据的原因。
&lt;p&gt;以后在实际应用中，采用分区技术确实能够有效提高性能得到验证后，再回来补充性能部分的内容。
&lt;p&gt;
&lt;p&gt;～～呵呵～～
&lt;p&gt;
&lt;p&gt;
&lt;p&gt;
&lt;p&gt;
&lt;p&gt;&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/119"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/119&lt;/font&gt;&lt;/u&gt;&lt;/a&gt; &lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+MySQL5%e7%9a%84%e5%88%86%e5%8c%ba%e7%a0%94%e7%a9%b6&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!248.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!248.entry</guid><pubDate>Tue, 20 Mar 2007 01:25:00 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!248/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!248.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:25:00Z</dcterms:modified></item><item><title>OpenVPN快速应用</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!247.entry</link><description>&lt;div&gt;
&lt;h3&gt;OpenVPN快速应用&lt;/h3&gt;&lt;span&gt;jimmy | 31 一月, 2007 21:01&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;本文要点：
&lt;p&gt;如何快速搭建一个单Client-Server的VPN应用，适用Windows的客户端，Linux的服务器端。目的是能够快速连入机房环境，更有效的维护和管理服务系统。
&lt;p&gt;对于如何用OpenVPN构架一个企业的通用VPN应用，本文并不适宜。
&lt;p&gt;参考：
&lt;h1&gt;&lt;a href="http://openvpn.net/static.html"&gt;&lt;font color="#0000ff" size=3&gt;&lt;u&gt;OpenVPN&lt;sup&gt;TM&lt;/sup&gt; Static Key Mini-HOWTO&lt;/u&gt;&lt;/font&gt;&lt;/a&gt;&lt;/h1&gt;
&lt;p&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;&lt;/font&gt;&lt;/u&gt;
&lt;p&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;&lt;/font&gt;&lt;/u&gt;&lt;br&gt;
&lt;p&gt;首先，下载安装OpenVPN。
&lt;p&gt;（假定： 当前服务器外网IP为 &lt;a href="http://www.jimmydong.com/blog/post/1/www.myserver.com"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;www.myserver.com&lt;/font&gt;&lt;/u&gt;&lt;/a&gt; ，内网IP为 192.168.0.3）
&lt;p&gt;生成公共Key：&lt;pre&gt;&lt;b&gt;&lt;b&gt;openvpn --genkey --secret openvpn_static.key&lt;/b&gt;&lt;/b&gt;&lt;/pre&gt;
&lt;p&gt;将Key放到C:下，然后复制一份到服务器/etc下。
&lt;p&gt;&lt;br&gt;服务器端编辑配置文件：
&lt;p&gt;#vi /etc/openvpn.cfg
&lt;p&gt;dev tun&lt;br&gt;ifconfig 10.8.0.1 10.8.0.2&lt;br&gt;secret /etc/openvpn_static.key&lt;br&gt;keepalive 10 60&lt;br&gt;ping-timer-rem&lt;br&gt;persist-tun&lt;br&gt;persist-key&lt;br&gt;user root&lt;br&gt;group root&lt;br&gt;daemon
&lt;p&gt;启动服务：
&lt;p&gt;/usr/local/sbin/openvpn /etc/openvpn.cfg
&lt;p&gt;开启IP转发：&lt;pre&gt;&lt;b&gt;&lt;b&gt;echo 1 &amp;gt; /proc/sys/net/ipv4/ip_forward&lt;/b&gt;&lt;/b&gt;&lt;/pre&gt;
&lt;p&gt;编辑客户端配置文件： c:openvpn.ovpn
&lt;p&gt;&lt;br&gt;remote &lt;a href="http://www.jimmydong.com/blog/post/1/www.myserver.com&amp;lt;br"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;www.myserver.com&lt;br&gt;&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;/&amp;gt;dev tun&lt;br&gt;ifconfig 10.8.0.2 10.8.0.1&lt;br&gt;secret C:openvpn_static.key&lt;br&gt;keepalive 10 60&lt;br&gt;ping-timer-rem&lt;br&gt;persist-tun&lt;br&gt;persist-key&lt;br&gt;route 192.168.0.0 255.255.0.0
&lt;p&gt;&lt;br&gt;配置文件上点右键，选择“start openvpn on this config file”，即可连入服务器。
&lt;p&gt;同时，可以访问到与服务器同一局网的机器。对于需要连入服务器环境管理多台机器是非常方便的。
&lt;p&gt;
&lt;p&gt;~~呵呵~~
&lt;p&gt;&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/117"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/117&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+OpenVPN%e5%bf%ab%e9%80%9f%e5%ba%94%e7%94%a8&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!247.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!247.entry</guid><pubDate>Tue, 20 Mar 2007 01:24:07 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!247/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!247.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:24:07Z</dcterms:modified></item><item><title>关于团队精神的探索</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!246.entry</link><description>&lt;div&gt;
&lt;h3&gt;关于团队精神的探索&lt;/h3&gt;&lt;span&gt;jimmy | 21 一月, 2007 22:55&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;其实谈不上什么探索，只是一些自己的困惑和思考。上周本来使安排了时间进行组员的谈话的，中间意外插入了跟另一个Team的Leader一席交谈，有很多的感触。于是决定花时间先反思一下，整理清自己的思路。
&lt;p&gt;当然，对自己不足的思考是很多的，就不在这里敲了，免得变成检讨书。这些反思继续向深处挖掘，便有一大堆的问题。这些个问题缠绕在一起，似乎每一个的答案都依赖着其它的问题，像是一个死循环。比起写程序难的多。
&lt;p&gt;&lt;img style="" src="http://www.jimmydong.com/blog/resserver.php?blogId=1&amp;amp;resource=snap003.png"&gt;
&lt;p&gt;团队精神依赖团队目标——团队精神如果没有统一目标来支撑，就会流于空洞和不切实际；
&lt;p&gt;团队目标依赖个人努力——统一的目标没有每个人的努力推动，就不可能得到贯彻和实现；
&lt;p&gt;个人努力依赖个人目标——最强的个人动力的根源，不是来自管理手段或者是逼迫，而是来自于对个人目标或者个人理想的不懈追求；
&lt;p&gt;个人目标依赖团队精神——每个人的个人目标，很难是一样的，甚至常常会产生冲突或造成不利的内耗。多样的个人目标，如何统一到团队的共同目标上去？这就需要团队精神。
&lt;p&gt;按程序的求解方式，就陷入循环，似乎得不到解决了。每一个环节的优化都对下一级提出更多依赖，从而使如果确定方式方法变得异常艰难。但是如果反过来看，每一个环节的改善都是为其上的环节构筑更好的支撑，整个循环就变得更顺畅。在处理每个环节时，不是着眼在环节本身依赖的条件，而是如何能够更有利于其上层的环节，很多问题就变得清晰起来。&lt;br&gt;
&lt;p&gt;1，个体的差异是必须承认和接受的。
&lt;p&gt;作为团队的Leader，需要关心团队中的每一个人，从了解到理解，从理解到尊重。每个人要的都是不同的，有的人是怀抱着长远的理想，有的人是渴望自身成功，有的人是为了有稳定愉快的工作环境，有的人是为了感激，有的人是为了物质收益…… 所有这些，没有绝对的标准去衡量哪个比哪个更好，更没有什么对或者错。每个人的个人选择，都是需要尊重的。只有基于理解和尊重之上的帮助，才能真正帮助别人。这是调动每个人充分发挥个人才能的基础。
&lt;p&gt;2，每个人都应该为自己的目标或者理想去努力。
&lt;p&gt;时间，是真正属于自己的东西，正是时间构成了我们的生命。我们每一天的时间，流逝了就不再了。每天，投入到工作中的时间也是如此。既然每天把时间放在这里，就应该对其负责，不能任其白白过去，应该不断努力使时间更有意义。作为团队的Leader，同时作为朋友，负有责任去不断提醒，更重要是不断帮助大家客服困难。在这里，方式和方法就很重要，我还很欠缺，不知道如何去做，也需要大家来帮助我。比如，如何改进交流和沟通？如何鼓励和激励？如何坦然去面对缺点和不足？……如果我能够在这方面有进步，会另文与大家分享。
&lt;p&gt;可以确定的是，只有每个人的积极性得到调动，才能更好的工作，从而推动整体工作顺利向前，去达成团队的共同目标。
&lt;p&gt;3，团队的共同目标。
&lt;p&gt;每个人都渴望是一个优秀团队的一员，因团队的成功而骄傲，因自己的贡献而使团队自豪。只有团队的进步，取得成绩，个人才能得到更多的回报。团队目标必须明确，而且需要有明确的规则和制度去保证。在这方面有很多经验可以借鉴，我们也做了很多的尝试和努力。
&lt;p&gt;去年看了不少关于体育的影片，《Remember The Titans》、《Glory Road》、《Invincible》、《Gridiron Gang》、《Facing The Giants》，有很多感触，真的很想能够跟团队在一起观看一起分享影片中那种团队获得成功的感动。在向共同目标努力的过程中，大家一起克服困难，互相帮助，团队的精神才会深入每个人的内心，感召和改变着每一个人。
&lt;p&gt;4，我们需要的团队精神。
&lt;p&gt;我还没有完全想好。从我的感觉上，应该具备这些要素：积极向上，愉快坦诚，注重沟通，互相帮助，敢挑重担，勇于负责。应该可以影响到个体，更积极自觉的挖掘和发现个人目标与团队目标的一致性，更主动自愿的将自己的个人目标与团队中其他人的个人目标保持和谐和一致。在这样的团队精神下，能够协助个人建立现实环境更合理更可实现的个人目标。
&lt;p&gt;单纯用业绩来衡量一个团队是否优秀的团队，常常是片面的，因为里面有很多环境、时间的因素。我觉得能够在以上所说四个环节上不断改进优化，从而达成各环节互相推动的正循环，才算是一个优秀的团队。因为只有这样的团队，才能保证在客观条件下达成最好的成果，才能保证团队中的成员更顺利更健康的发展。
&lt;p&gt;为自己，为大家，让我们一起积极努力吧。
&lt;p&gt;～～呵呵～～&lt;br&gt;&lt;br&gt;欢迎转贴，请注明来处。【本帖地址】: &lt;a href="http://www.jimmydong.com/blog/post/1/116"&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;http://www.jimmydong.com/blog/post/1/116&lt;/font&gt;&lt;/u&gt;&lt;/a&gt;&lt;/div&gt;&lt;img src="http://c.services.spaces.live.com/CollectionWebService/c.gif?cid=-294328527923311756&amp;page=RSS%3a+%e5%85%b3%e4%ba%8e%e5%9b%a2%e9%98%9f%e7%b2%be%e7%a5%9e%e7%9a%84%e6%8e%a2%e7%b4%a2&amp;referrer=" width="1px" height="1px" border="0" alt=""&gt;&lt;img style="position:absolute" alt="" width="0px" height="0px" src="http://c.live.com/c.gif?NC=31263&amp;amp;NA=1149&amp;amp;PI=73329&amp;amp;RF=&amp;amp;DI=3919&amp;amp;PS=85545&amp;amp;TP=jdlog.spaces.live.com&amp;amp;GT1=jdlog"&gt;</description><comments>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!246.entry#comment</comments><guid isPermaLink="true">http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!246.entry</guid><pubDate>Tue, 20 Mar 2007 01:23:11 GMT</pubDate><slash:comments>0</slash:comments><msn:type>blogentry</msn:type><live:type>blogentry</live:type><live:typelabel>Blog entry</live:typelabel><wfw:commentRss>http://jdlog.spaces.live.com/blog/cns!FBEA55C365DE0B74!246/comments/feed.rss</wfw:commentRss><wfw:comment>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!246.entry#comment</wfw:comment><dcterms:modified>2007-03-20T01:23:11Z</dcterms:modified></item><item><title>SQLite函数速查</title><link>http://jdlog.spaces.live.com/Blog/cns!FBEA55C365DE0B74!245.entry</link><description>&lt;div&gt;
&lt;h3&gt;SQLite函数速查&lt;/h3&gt;&lt;span&gt;jimmy | 17 一月, 2007 11:15&lt;/span&gt; 
&lt;p&gt;
&lt;p&gt;
&lt;p&gt;常用操作DEMO：&lt;pre&gt;&amp;lt;?
&lt;span&gt;/**
 *
 * SQLite ç��å� ç§�ä¸�å��æ��ä½�æ�¹æ³�
 *
 * by jimmy 20060911
 */&lt;/span&gt;
&lt;span&gt;include&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;../include/config.inc.php&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;&amp;quot;&amp;lt;hr&amp;gt;PDOæ�¹å¼�&amp;lt;hr&amp;gt;&amp;quot;&lt;/span&gt;;
try &lt;span&gt;{&lt;/span&gt; 
    &lt;span&gt;$conn&lt;/span&gt; = &lt;span&gt;new&lt;/span&gt; PDO&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'sqlite2:jimmy.sqlite'&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;; 
    &lt;span&gt;$string&lt;/span&gt; = &lt;span&gt;'working...&amp;lt;br&amp;gt;'&lt;/span&gt;;
    &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;$conn&lt;/span&gt;-&amp;gt;&lt;span&gt;quote&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$string&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;    &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;'PDO Connection  Ok'&lt;/span&gt;,&lt;span&gt;'&amp;lt;br&amp;gt;'&lt;/span&gt;; 
    &lt;span&gt;$conn&lt;/span&gt;-&amp;gt;&lt;span&gt;beginTransaction&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;; 
    &lt;span&gt;$conn&lt;/span&gt;-&amp;gt;&lt;span&gt;exec&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;INSERT INTO test values(null,'pdo','pdo_test...')&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;; 
 &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;$conn&lt;/span&gt;-&amp;gt;&lt;span&gt;commit&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
    &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;'A Transaction: Insert Data ok'&lt;/span&gt;,&lt;span&gt;'&amp;lt;br&amp;gt;'&lt;/span&gt;; 
&lt;span&gt;}&lt;/span&gt; catch &lt;span&gt;(&lt;/span&gt;PDOException &lt;span&gt;$e&lt;/span&gt;&lt;span&gt;)&lt;/span&gt; &lt;span&gt;{&lt;/span&gt; 
   &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;'Connection failed: '&lt;/span&gt; . &lt;span&gt;$e&lt;/span&gt;-&amp;gt;&lt;span&gt;getMessage&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;; 
&lt;span&gt;}&lt;/span&gt; echo &lt;span&gt;'get all data'&lt;/span&gt;,&lt;span&gt;'&amp;lt;br&amp;gt;'&lt;/span&gt;;
&lt;span&gt;$query&lt;/span&gt;=&lt;span&gt;$conn&lt;/span&gt;-&amp;gt;&lt;span&gt;query&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'SELECT * FROM test'&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;; 
&lt;span&gt;$result&lt;/span&gt;=&lt;span&gt;$query&lt;/span&gt;-&amp;gt;&lt;span&gt;fetchAll&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
trace&lt;span&gt;(&lt;/span&gt; &lt;span&gt;$result&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;; echo &lt;span&gt;'get data line by line'&lt;/span&gt;, &lt;span&gt;'&amp;lt;br&amp;gt;n'&lt;/span&gt;;
&lt;span&gt;$query&lt;/span&gt; = &lt;span&gt;$conn&lt;/span&gt;-&amp;gt;&lt;span&gt;prepare&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;SELECT * FROM test where id &amp;gt; ?&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;if&lt;/span&gt; &lt;span&gt;(&lt;/span&gt;&lt;span&gt;$query&lt;/span&gt;-&amp;gt;&lt;span&gt;execute&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;a href="http://www.php.net/array"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;array&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'1'&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;)&lt;/span&gt; &lt;span&gt;{&lt;/span&gt;
  &lt;span&gt;while&lt;/span&gt; &lt;span&gt;(&lt;/span&gt;&lt;span&gt;$row&lt;/span&gt; = &lt;span&gt;$query&lt;/span&gt;-&amp;gt;&lt;span&gt;fetch&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;)&lt;/span&gt; &lt;span&gt;{&lt;/span&gt;
    trace&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$row&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
  &lt;span&gt;}&lt;/span&gt;
&lt;span&gt;}&lt;/span&gt;
&lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;&amp;quot;&amp;lt;hr&amp;gt;SQLiteç±»&amp;lt;hr&amp;gt;&amp;quot;&lt;/span&gt;;
&lt;span&gt;$db&lt;/span&gt; = &lt;span&gt;new&lt;/span&gt; SQLiteDatabase&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'jimmy2'&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;query&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;INSERT INTO test VALUES(null,'sqlite','sqlite class')&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;'get data all'&lt;/span&gt;,&lt;span&gt;'&amp;lt;br&amp;gt;'&lt;/span&gt;;
&lt;span&gt;$result&lt;/span&gt; = &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;arrayQuery&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'SELECT * FROM test LIMIT 25'&lt;/span&gt;, SQLITE_ASSOC&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;foreach&lt;/span&gt; &lt;span&gt;(&lt;/span&gt;&lt;span&gt;$result&lt;/span&gt; &lt;span&gt;as&lt;/span&gt; &lt;span&gt;$entry&lt;/span&gt;&lt;span&gt;)&lt;/span&gt; &lt;span&gt;{&lt;/span&gt;
    &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;'title: '&lt;/span&gt; . &lt;span&gt;$entry&lt;/span&gt;&lt;span&gt;[&lt;/span&gt;&lt;span&gt;'title'&lt;/span&gt;&lt;span&gt;]&lt;/span&gt; . &lt;span&gt;'  content: '&lt;/span&gt; . &lt;span&gt;$entry&lt;/span&gt;&lt;span&gt;[&lt;/span&gt;&lt;span&gt;'content'&lt;/span&gt;&lt;span&gt;]&lt;/span&gt;;
&lt;span&gt;}&lt;/span&gt;
&lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;'&amp;lt;br&amp;gt;get data line by line'&lt;/span&gt;,&lt;span&gt;'&amp;lt;br&amp;gt;'&lt;/span&gt;;
&lt;span&gt;$result&lt;/span&gt; = &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;query&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;SELECT * FROM test LIMIT 25&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;while&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$row&lt;/span&gt;=&lt;span&gt;$result&lt;/span&gt;-&amp;gt;&lt;span&gt;fetch&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;{&lt;/span&gt;
 &lt;a href="http://www.php.net/print_r"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;print_r&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$row&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;}&lt;/span&gt;
&lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;&amp;quot;&amp;lt;hr&amp;gt;pear MDB2&amp;lt;hr&amp;gt;&amp;quot;&lt;/span&gt;;
&lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;&amp;quot;wait...&amp;quot;&lt;/span&gt;;echo &lt;span&gt;&amp;quot;&amp;lt;hr&amp;gt;Zendç±»&amp;lt;hr&amp;gt;&amp;quot;&lt;/span&gt;;
&lt;span&gt;require_once&lt;/span&gt; &lt;span&gt;'Zend.php'&lt;/span&gt;;
Zend::&lt;span&gt;loadClass&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'Zend_Db'&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;$params&lt;/span&gt; = &lt;a href="http://www.php.net/array"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;array&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;(&lt;/span&gt;&lt;span&gt;'dbname'&lt;/span&gt; =&amp;gt; &lt;span&gt;'jimmy.sqlite'&lt;/span&gt;,&lt;span&gt;'sqlite2'&lt;/span&gt; =&amp;gt; &lt;span&gt;TRUE&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;$db&lt;/span&gt; = Zend_Db::&lt;span&gt;factory&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;'PDO_SQLITE'&lt;/span&gt;, &lt;span&gt;$params&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;try &lt;span&gt;{&lt;/span&gt;    
    &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;beginTransaction&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
    &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;query&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;INSERT INTO test VALUES(null,'sqlite','zend sqlite')&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;   
    &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;&amp;quot;&amp;lt;br&amp;gt;Insert OK &amp;quot;&lt;/span&gt;.&lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;lastInsertId&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;; 
    &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;commit&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;}&lt;/span&gt; 
catch &lt;span&gt;(&lt;/span&gt;Exception &lt;span&gt;$e&lt;/span&gt;&lt;span&gt;)&lt;/span&gt; &lt;span&gt;{&lt;/span&gt;    
    &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;rollBack&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;    
    &lt;a href="http://www.php.net/echo"&gt;&lt;span&gt;&lt;u&gt;&lt;font color="#0000ff"&gt;echo&lt;/font&gt;&lt;/u&gt;&lt;/span&gt;&lt;/a&gt; &lt;span&gt;$e&lt;/span&gt;-&amp;gt;&lt;span&gt;getMessage&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;}&lt;/span&gt;
&lt;span&gt;$result&lt;/span&gt; = &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;fetchAll&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;SELECT * FROM test&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
trace&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$result&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;&lt;span&gt;$query&lt;/span&gt; = &lt;span&gt;$db&lt;/span&gt;-&amp;gt;&lt;span&gt;query&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;&amp;quot;SELECT * FROM test&amp;quot;&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;while&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$row&lt;/span&gt;=&lt;span&gt;$query&lt;/span&gt;-&amp;gt;&lt;span&gt;fetch&lt;/span&gt;&lt;span&gt;(&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;&lt;span&gt;{&lt;/span&gt;
    trace&lt;span&gt;(&lt;/span&gt;&lt;span&gt;$row&lt;/span&gt;&lt;span&gt;)&lt;/span&gt;;
&lt;span&gt;}&lt;/span&gt;
?&amp;gt;&lt;/pre&gt;&lt;br&gt;
&lt;p&gt;常用语法：
&lt;p&gt;
&lt;table cellspacing=1 cellpadding=5 width="100%" bgcolor="#000000" border=0&gt;
&lt;tbody&gt;
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;结构定义&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;CREATE TABLE
&lt;td&gt;
&lt;p&gt;创建新表。
&lt;p&gt;&lt;strong&gt;语法：&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;CREATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TEMP &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; TEMPORARY&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; TABLE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;font size=4&gt;&lt;big&gt;(&lt;/big&gt;&lt;/font&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-def&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-def&lt;/font&gt;&lt;/i&gt;]&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;constraint&lt;/font&gt;&lt;/i&gt;]&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;&lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;CREATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TEMP &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; TEMPORARY&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; TABLE &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;.&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; AS &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select-statement&lt;/font&gt;&lt;/i&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-def&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;type&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[[&lt;b&gt;&lt;font color="#2c2cf0"&gt;CONSTRAINT &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-constraint&lt;/font&gt;&lt;/i&gt;]&lt;font size=4&gt;&lt;big&gt;*&lt;/big&gt;&lt;/font&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;type&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;typename&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;typename&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;number&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;typename&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;number&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;number&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-constraint&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;NOT NULL &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;PRIMARY KEY &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;sort-order&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;UNIQUE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;CHECK &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;DEFAULT &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;value&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;COLLATE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;collation-name&lt;/font&gt;&lt;/i&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;constraint&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;PRIMARY KEY &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;UNIQUE &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;CHECK &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-clause&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;ON CONFLICT &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-algorithm&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/strong&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;CREATE VIEW
&lt;td&gt;
&lt;p&gt;创建一个视图（虚拟表），该表以另一种方式表示一个或多个表中的数据。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;CREATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TEMP &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; TEMPORARY&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; VIEW &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;.&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;view-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; AS &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select-statement&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;br&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;span style="color:blue"&gt;CREATE VIEW&lt;/span&gt; master_view &lt;span style="color:blue"&gt;AS&lt;/span&gt;&lt;br&gt;&lt;span style="color:blue"&gt;SELECT&lt;/span&gt; * &lt;span style="color:blue"&gt;FROM&lt;/span&gt; sqlite_master &lt;span style="color:blue"&gt;WHERE&lt;/span&gt; type='view';&lt;br&gt;&lt;strong&gt;说明：&lt;/strong&gt;&lt;br&gt;创建一个名为master_view的视图，其中包括sqlite_master这个表中的所有视图表。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;CREATE TRIGGER
&lt;td&gt;
&lt;p&gt;创建触发器，触发器是一种特殊的存储过程，在用户试图对指定的表执行指定的数据修改语句时自动执行。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;CREATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TEMP &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; TEMPORARY&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; TRIGGER &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; BEFORE &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; AFTER &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;database-event&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; ON &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-action&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;CREATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TEMP &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; TEMPORARY&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; TRIGGER &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; INSTEAD OF&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;database-event&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; ON &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;view-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-action&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;database-event&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DELETE &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;br&gt;INSERT &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;br&gt;UPDATE &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;br&gt;UPDATE OF &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-action&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; FOR EACH ROW &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; FOR EACH STATEMENT &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; WHEN &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expression&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;br&gt;BEGIN &lt;br&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-step&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; ; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-step&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; ; &lt;/font&gt;&lt;/b&gt;]&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;END&lt;/font&gt;&lt;/b&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-step&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;update-statement&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;insert-statement&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;delete-statement&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select-statement&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;br&gt;CREATE TRIGGER update_customer_address UPDATE OF address ON customers &lt;br&gt;BEGIN&lt;br&gt;UPDATE orders SET address = new.address WHERE customer_name = old.name;&lt;br&gt;END;&lt;br&gt;&lt;strong&gt;说明：&lt;/strong&gt;&lt;font size=2&gt;创建了一个名为update_customer_address的触发器，当用户更新customers表中的address字段时，将触发并更新orders表中的address字段为新的值。&lt;br&gt;比如执行如下一条语句：&lt;/font&gt;UPDATE customers SET address = '1 Main St.' WHERE name = 'Jack Jones';&lt;br&gt;数据库将自动执行如下语句：&lt;br&gt;UPDATE orders SET address = '1 Main St.' WHERE customer_name = 'Jack Jones';
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;CREATE INDEX
&lt;td&gt;
&lt;p&gt;为给定表或视图创建索引。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;CREATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;UNIQUE&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; INDEX &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;index-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;br&gt;ON &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-name&lt;/font&gt;&lt;/i&gt;]&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;font size=4&gt;&lt;big&gt;)&lt;/big&gt;&lt;/font&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; ON CONFLICT &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-algorithm&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-name&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; COLLATE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;collation-name&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; ASC &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; DESC &lt;/font&gt;&lt;/b&gt;]&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;span style="color:blue"&gt;CREATE INDEX&lt;/span&gt; idx_email &lt;span style="color:blue"&gt;ON&lt;/span&gt; customers (email);&lt;br&gt;&lt;strong&gt;说明：&lt;/strong&gt;&lt;br&gt;为customers表中的email创建一个名为idx_email的字段。
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;结构删除&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;DROP TABLE
&lt;td&gt;
&lt;p&gt;删除表定义及该表的所有索引。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DROP TABLE &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;.&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;br&gt;DROP TABLE customers;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;DROP VIEW
&lt;td&gt;
&lt;p&gt;删除一个视图。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DROP VIEW &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;view-name&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;br&gt;DROP VIEW master_view;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;DROP TRIGGER
&lt;td&gt;
&lt;p&gt;删除一个触发器。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DROP TRIGGER &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;trigger-name&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;font size=2&gt;DROP TRIGGER &lt;/font&gt;update_customer_address;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;DROP INDEX
&lt;td&gt;
&lt;p&gt;删除一个索引。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DROP INDEX &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;index-name&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;例子：&lt;/strong&gt;DROP INDEX idx_email;
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;数据操作&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;INSERT
&lt;td&gt;
&lt;p&gt;将新行插入到表。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;INSERT &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;OR &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-algorithm&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; INTO &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;(&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;)&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; VALUES&lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;value-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;INSERT &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;OR &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-algorithm&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; INTO &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;(&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;)&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select-statement&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;UPDATE
&lt;td&gt;
&lt;p&gt;更新表中的现有数据。
&lt;p&gt;&lt;strong&gt;语法：&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;UPDATE &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; OR &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-algorithm&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;SET &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;assignment&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;assignment&lt;/font&gt;&lt;/i&gt;]&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;WHERE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;assignment&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;=&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/strong&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;DELETE
&lt;td&gt;
&lt;p&gt;从表中删除行。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DELETE FROM &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;WHERE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;]&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;SELECT
&lt;td&gt;
&lt;p&gt;从表中检索数据。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;SELECT &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;ALL &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; DISTINCT&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;result&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;FROM &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-list&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;WHERE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;GROUP BY &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr-list&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;HAVING &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;compound-op&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select&lt;/font&gt;&lt;/i&gt;]&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;ORDER BY &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sort-expr-list&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;LIMIT &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;integer&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[(&lt;b&gt;&lt;font color="#2c2cf0"&gt; OFFSET &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;)&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;integer&lt;/font&gt;&lt;/i&gt;]]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;result&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;result-column&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;result-column&lt;/font&gt;&lt;/i&gt;]&lt;font size=4&gt;&lt;big&gt;*&lt;/big&gt;&lt;/font&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;result-column&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt; &lt;big&gt;&lt;font size=4&gt;*&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;AS&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;string&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-list&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;join-op&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;join-args&lt;/font&gt;&lt;/i&gt;]&lt;font size=4&gt;&lt;big&gt;*&lt;/big&gt;&lt;/font&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;AS &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;alias&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;&lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;AS &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;alias&lt;/font&gt;&lt;/i&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;join-op&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;NATURAL&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;LEFT &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; RIGHT &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; FULL&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;OUTER &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; INNER &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; CROSS&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; JOIN&lt;/font&gt;&lt;/b&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;join-args&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;ON &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;USING &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;id-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sort-expr-list&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;sort-order&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;,&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;expr&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;sort-order&lt;/font&gt;&lt;/i&gt;]]&lt;font size=4&gt;&lt;big&gt;*&lt;/big&gt;&lt;/font&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sort-order&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; COLLATE &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;collation-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; ASC &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; DESC &lt;/font&gt;&lt;/b&gt;]
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;compound_op&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;UNION &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; UNION ALL &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; INTERSECT &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; EXCEPT&lt;/font&gt;&lt;/b&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;REPLACE
&lt;td&gt;
&lt;p&gt;类似INSERT
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;REPLACE INTO &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; VALUES &lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;value-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;REPLACE INTO &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;big&gt;&lt;font size=4&gt;(&lt;/font&gt;&lt;/big&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;column-list&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;)&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;select-statement&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;事务处理&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;BEGIN TRANSACTION
&lt;td&gt;
&lt;p&gt;标记一个事务的起始点。
&lt;p&gt;&lt;strong&gt;语法：&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;BEGIN &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TRANSACTION &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;]]&lt;/tbody&gt;&lt;/table&gt;&lt;/strong&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;END TRANSACTION
&lt;td&gt;
&lt;p&gt;标记一个事务的终止。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;END &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TRANSACTION &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;]]&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;COMMIT TRANSACTION
&lt;td&gt;
&lt;p&gt;标志一个事务的结束。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;COMMIT &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TRANSACTION &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;]]&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;ROLLBACK TRANSACTION
&lt;td&gt;
&lt;p&gt;将事务回滚到事务的起点。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;ROLLBACK &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;TRANSACTION &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;]]&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;其他操作&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;COPY
&lt;td&gt;
&lt;p&gt;主要用于导入大量的数据。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;COPY &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; OR &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;conflict-algorithm&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;big&gt;&lt;font size=4&gt;.&lt;/font&gt;&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;table-name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; FROM &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;filename&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt; USING DELIMITERS &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;delim&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;]&lt;/tbody&gt;&lt;/table&gt;&lt;strong&gt;例子：&lt;/strong&gt;&lt;br&gt;&lt;span style="color:blue"&gt;COPY&lt;/span&gt; customers &lt;span style="color:blue"&gt;FROM&lt;/span&gt; customers.csv;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;EXPLAIN
&lt;td&gt;
&lt;p&gt;
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;EXPLAIN &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;PRAGMA
&lt;td&gt;
&lt;p&gt;
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;PRAGMA &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;name&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;= &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;value&lt;/font&gt;&lt;/i&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;big&gt;&lt;font size=4&gt;|&lt;/font&gt;&lt;/big&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;&lt;br&gt;PRAGMA &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;function&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;(&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;arg&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0" size=4&gt;&lt;big&gt;)&lt;/big&gt;&lt;/font&gt;&lt;/b&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;VACUUM
&lt;td&gt;
&lt;p&gt;
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;VACUUM &lt;/font&gt;&lt;/b&gt;[&lt;i&gt;&lt;font color="#ff3434"&gt;index-or-table-name&lt;/font&gt;&lt;/i&gt;]&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;ATTACH DATABASE
&lt;td&gt;
&lt;p&gt;附加一个数据库到当前的数据库连接。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-statement&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;ATTACH &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;DATABASE&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;database-filename&lt;/font&gt;&lt;/i&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt; AS &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;DETTACH DATABASE
&lt;td&gt;
&lt;p&gt;从当前的数据库分离一个使用ATTACH DATABASE附加的数据库。
&lt;p&gt;&lt;strong&gt;语法：&lt;/strong&gt;&lt;br&gt;
&lt;table cellpadding=10&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td valign=top align=right&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;sql-command&lt;/font&gt;&lt;/i&gt; ::=
&lt;td&gt;&lt;b&gt;&lt;font color="#2c2cf0"&gt;DETACH &lt;/font&gt;&lt;/b&gt;[&lt;b&gt;&lt;font color="#2c2cf0"&gt;DATABASE&lt;/font&gt;&lt;/b&gt;]&lt;b&gt;&lt;font color="#2c2cf0"&gt; &lt;/font&gt;&lt;/b&gt;&lt;i&gt;&lt;font color="#ff3434"&gt;database-name&lt;/font&gt;&lt;/i&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/tbody&gt;&lt;/table&gt;
&lt;p&gt;SQLite内建函数表
&lt;p&gt;
&lt;table cellspacing=1 cellpadding=5 width="100%" bgcolor="#000000" border=0&gt;
&lt;tbody&gt;
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;算术函数&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;abs(X)
&lt;td&gt;返回给定数字表达式的绝对值。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;max(X,Y[,...])
&lt;td&gt;返回表达式的最大值。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;min(X,Y[,...])
&lt;td&gt;返回表达式的最小值。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;random(*)
&lt;td&gt;返回随机数。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;round(X[,Y])
&lt;td&gt;返回数字表达式并四舍五入为指定的长度或精度。
&lt;tr bgcolor="#cccccc"&gt;
&lt;td colspan=2&gt;&lt;b&gt;字符处理函数&lt;/b&gt;
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;length(X)
&lt;td&gt;返回给定字符串表达式的字符个数。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;lower(X)
&lt;td&gt;将大写字符数据转换为小写字符数据后返回字符表达式。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;upper(X)
&lt;td&gt;返回将小写字符数据转换为大写的字符表达式。
&lt;tr bgcolor="#ffffff"&gt;
&lt;td&gt;substr(X,Y,Z)
&lt;t