Home > Database > Mysql Tutorial > body text

MySQL鲜为人知的几个特殊技巧

WBOY
Release: 2016-06-07 16:07:19
Original
831 people have browsed it

以XML格式查看查询结果 通过使用传统—xml 选项调用MySQL命令行客户程序,你可以以XML格式(而不是传统的列表形式)来查看。 MySQL查询结果 如果你打算将查询输出与其它程序集成在一起,这一技巧非常有用,这里是一个例子: 表A shell mysql --xml mysql SELEC

以XML格式查看查询结果

通过使用传统—xml 选项调用MySQL命令行客户程序,你可以以XML格式(而不是传统的列表形式)来查看。

MySQL查询结果

如果你打算将查询输出与其它程序集成在一起,这一技巧非常有用,这里是一个例子:

表A

shell> mysql --xml <br>mysql> SELECT * FROM test.stories;<br>1<br>This is a test<br>2<br>This is the second test<br>2rows in set (0.11 sec)
Copy after login

快速重建索引

通常情况下,如果你想改变服务器的全文搜索变量,你需要在表格中重新建立全文索引,以确保你的更新得到映射。这一操作将会花费大量的时间,特别是如果你需要处理很多数据的时候。一种快速的解决。

方法是使用REPAIR TABLE命令,以下为演示过程:

表B

mysql> REPAIR TABLE content QUICK; <br>+-----------+--------+----------+----------+<br>| Table| Op| Msg_type | Msg_text |<br>+-----------+--------+----------+----------+<br>| content| repair | status| OK|<br>+-----------+--------+----------+----------+<br>1 row in set (0.05 sec)
Copy after login

压缩一定的表格类型

如果你处理的是只读MyISAM表格,MySQL允许你将其压缩以节省磁盘空间。对此可以使用包括myisampack,如下所示:

表C

shell> myisampackmovies.MYI <br>Compressing movies.MYD: (146 records)<br>- Calculating statistics<br>- Compressing file<br>41.05%<br>
Copy after login


使用传统SQL

MySQL支持SQL查询中的传统用法,支持IF与CASE结构。以下是一个简单的例子:

表D

mysql> SELECT IF (priv=1, 'admin', 'guest') <br>As usertype FROM privs WHERE username = 'joe';<br>+----------+<br>| usertype |<br>+----------+<br>| admin|<br>+----------+<br>1 row in set (0.00 sec)<br><br>以CSV格式输出表格数据
Copy after login

MySQL 输出文件包含一个全部SQL命令列表。如果你想将输出文件导入到MySQL,这一功能非常实用,但如果目标程序(比如Excel)不能与SQL相互通讯,这一方法将行不通。在这种情况下,可以通过告诉MySQL

以CSV格式建立输出文件,这种CSV格式很方便地导入到绝大部分的程序。这里演示了 mysqldump的操作过程:

shell> mysqldump -T .<br>--fields-terminated-by=", " mydbmytable
Copy after login

这将在当前目录中生成一个文本文件,包含来自mydb.mytable列表中以逗号为间隔符的记录。

以激活strict模式减少“bad”数据的出现

MySQL服务器能够以多种不同的模式运行,而每一种都针对于特定的目的而优化。在默认情况下,没有设置模式。然而,通过在服务器命令行中添加以下选项可以很容易地改变模式的设置并将MySQL以“strict”模式运行:

shell> mysqld --sql_mode="STRICT_ALL_TABLES" &
Copy after login

在“strict”模式下,通过MySQL的中止查询执行并返回一个错误,服务器的很多自动修正功能都被无效化。同样,该模式下也将会执行更为严格的时间检查。

监视服务器

你可以通过运行SHOW STATUS命令获得一份服务器运行与统计的报告,包括打开连接的次数,激活查询次数,服务器正常运行时间等等。例如:

表E

Emysql> SHOW STATUS; <br>+------------------+-------+<br>| Variable_name| Value |<br>+------------------+-------+<br>| Aborted_clients| 0|<br>| Aborted_connects | 0|<br>...<br>| Uptime| 851|<br>+------------------+-------+<br>156 rows in set (0.16 sec)
Copy after login

自动返回CREATE TABLE代码

MySQL允许你自动获得SQL命令重新建立一个特定的表格。只简单地运行SHOW CREATE TABLE命令,并查看表格建立代码,如下所示:

表F

mysql> SHOW CREATE TABLE products; <br>---------------------------------------<br>| Table| Create Table<br>+----------+---------------------------<br>| products | CREATE TABLE `products` (<br>`id` int(8) NOT NULL auto_increment,<br>`name` varchar(255) NOT NULL default '',<br>`price` int(10) default NULL,<br>PRIMARY KEY(`id`)<br>) ENGINE=InnoDB DEFAULT CHARSET=latin1 |<br>+----------+----------------------------<br>1 row in set (0.27 sec)
Copy after login

建立一个更为有用的命令提示

在缺省情况下,MySQL命令行客户程序显示一个简单的mysql>提示符。然而,你可以使用特定的修改内容来改变这一提示符使之变得更为有效,这些内容包括:当前用户名称,主机名称,以及当前选择的数据库。如下所示:

表G

mysql> prompt \U:/\d> <br>PROMPT set to '\U:/\d>'<br>root@localhost:/db1>
Copy after login

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template