mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-22 23:00:57 +08:00
201 lines
9.0 KiB
Markdown
201 lines
9.0 KiB
Markdown
给linux用户的11个高级MySQL数据库面试问题和答案
|
||
================================================================================
|
||
我们已经发表了两篇MySQL的文章,非常感谢Tecmint社区的大力支持.这是MySQL面试系列的第三篇文章,并且在面试专栏中排第16.
|
||
- [15个基本的MySQL面试问题][1]
|
||
- [给中级人员的10个MySQL面试问题][1]
|
||
|
||
![11个MySQL面试问题](http://www.tecmint.com/wp-content/uploads/2014/06/MySQL-Interview-Questions.jpeg)
|
||
|
||
感谢你们这一路上对我们的支持.这篇文章主要针对MySQL的实用性,讲面试方面的问题.
|
||
|
||
### 1. 如何使用SELECT语句找到你正在运行的服务器的版本并打印出当前数据库的名称? ###
|
||
**Ans**:下面的语句的结果会显示服务器的版本和当前的数据库名称
|
||
|
||
mysql> SELECT VERSION(), DATABASE();
|
||
|
||
+-------------------------+------------+
|
||
| VERSION() | DATABASE() |
|
||
+-------------------------+------------+
|
||
| 5.5.34-0ubuntu0.13.10.1 | NULL |
|
||
+-------------------------+------------+
|
||
1 row in set (0.06 sec)
|
||
|
||
在Database一栏中显示**NULL**是因为我们当前没有选择任何数据库.因此,使用下面的语句先选择一个数据库,就能看到相应的结果.
|
||
|
||
mysql> use Tecmint;
|
||
|
||
Reading table information for completion of table and column names
|
||
You can turn off this feature to get a quicker startup with -A
|
||
|
||
Database changed
|
||
|
||
----------
|
||
|
||
mysql> select VERSION(), DATABASE();
|
||
|
||
+-------------------------+------------+
|
||
| VERSION() | DATABASE() |
|
||
+-------------------------+------------+
|
||
| 5.5.34-0ubuntu0.13.10.1 | tecmint |
|
||
+-------------------------+------------+
|
||
1 row in set (0.00 sec)
|
||
|
||
### 2. 使用非运算符(!)从表"Tecmint"中列出除了user等于"SAM"的所有记录
|
||
|
||
**Ans**:使用下面的语句
|
||
|
||
mysql> SELECT * FROM Tecmint WHERE user !=SAM;
|
||
|
||
+---------------------+---------+---------+---------+---------+-------+
|
||
| date | user | host | root | local | size |
|
||
+---------------------+---------+---------+---------+---------+-------+
|
||
| 2001-05-14 14:42:21 | Anthony | venus | barb | venus | 98151 |
|
||
| 2001-05-15 08:50:57 | TIM | venus | phil | venus | 978 |
|
||
+---------------------+---------+---------+---------+---------+-------+
|
||
|
||
### 3. 是否能够使用非运算符(!)来实现'AND'运算
|
||
|
||
**Ans**: 我们使用’=’号和OR运算符或者'!='和AND运算符,下面是'='和AND运算符的例子
|
||
|
||
mysql> SELECT * FROM mail WHERE user = SAM AND root = phil
|
||
|
||
'!='和OR运算符的例子
|
||
|
||
mysql> SELECT * FROM mail WHERE user != SAM OR root != phil
|
||
|
||
+---------------------+---------+---------+---------+---------+-------+
|
||
| date | user | host | root | local | size |
|
||
+---------------------+---------+---------+---------+---------+-------+
|
||
| 2001-05-14 14:42:21 | Anthony | venus | barb | venus | 98151 |
|
||
+---------------------+---------+---------+---------+---------+-------+
|
||
|
||
- = : 等于
|
||
- != : 不等于
|
||
- ! : 非运算符
|
||
|
||
AND和OR在MySQL中被看作加入运算符
|
||
|
||
### 4. IFNULL()语句在MySQL中有什么作用? ###
|
||
|
||
**Ans**: **IFNULL**语句的使用使得MySQL中的查询更加精确。IFNULL()语句先测试它的的一个参数,若不为空就返回该参数的值,否则返回第二个参数的值
|
||
|
||
mysql> SELECT name, IFNULL(id,'Unknown') AS 'id' FROM taxpayer;
|
||
|
||
+---------+---------+
|
||
| name | id |
|
||
+---------+---------+
|
||
| bernina | 198-48 |
|
||
| bertha | Unknown |
|
||
| ben | Unknown |
|
||
| bill | 475-83 |
|
||
+---------+---------+
|
||
|
||
### 5. 如果你只想知道从一个结果集的开头或者结尾开始的特定条数的行记录改如何实现?
|
||
|
||
**Ans**: 我们可以用**LIMIT**和**ORDER BY**从句。
|
||
|
||
#### 显示一行记录 ####
|
||
|
||
mysql> SELECT * FROM name LIMIT 1;
|
||
|
||
+----+------+------------+-------+----------------------+------+
|
||
| id | name | birth | color | foods | cats |
|
||
+----+------+------------+-------+----------------------+------+
|
||
| 1 | Fred | 1970-04-13 | black | lutefisk,fadge,pizza | 0 |
|
||
+----+------+------------+-------+----------------------+------+
|
||
|
||
#### 显示5行记录 ####
|
||
|
||
mysql> SELECT * FROM profile LIMIT 5;
|
||
|
||
+----+------+------------+-------+-----------------------+------+
|
||
| id | name | birth | color | foods | cats |
|
||
+----+------+------------+-------+-----------------------+------+
|
||
| 1 | Fred | 1970-04-13 | black | lutefisk,fadge,pizza | 0 |
|
||
| 2 | Mort | 1969-09-30 | white | burrito,curry,eggroll | 3 |
|
||
| 3 | Brit | 1957-12-01 | red | burrito,curry,pizza | 1 |
|
||
| 4 | Carl | 1973-11-02 | red | eggroll,pizza | 4 |
|
||
| 5 | Sean | 1963-07-04 | blue | burrito,curry | 5 |
|
||
+----+------+------------+-------+-----------------------+------+
|
||
|
||
#### 显示按照ORDER BY排序后的第一条记录 ####
|
||
|
||
mysql> SELECT * FROM profile ORDER BY birth LIMIT 1;
|
||
|
||
+----+------+------------+-------+----------------+------+
|
||
| id | name | birth | color | foods | cats |
|
||
+----+------+------------+-------+----------------+------+
|
||
| 9 | Dick | 1952-08-20 | green | lutefisk,fadge | 0 |
|
||
+----+------+------------+-------+----------------+------+
|
||
|
||
### 6. Oracle 和 MySQL该如何选择? ###
|
||
|
||
**Ans**: 它们都有各自的优点和缺点。
|
||
|
||
#### 选择MySQL而不选orcale的原因 ####
|
||
|
||
- 开源
|
||
- 轻便快捷
|
||
- 有命令行和图形界面
|
||
- 能通过查询器进行数据库的管理
|
||
|
||
### 7. MySQL中如何得到当前日期? ###
|
||
|
||
**Ans**: 使用CURRENT_DATE()函数
|
||
|
||
mysql> SELECT CURRENT_DATE();
|
||
|
||
+----------------+
|
||
| CURRENT_DATE() |
|
||
+----------------+
|
||
| 2014-06-17 |
|
||
+----------------+
|
||
|
||
### 8. MySQL中如何将表导出为XML文件? ###
|
||
|
||
**Ans**: 使用'-e'(export)参数来把MySQL表或整个数据库导出到XML文件。当处理大型表的时候或许我们需要手动导出,但是只是导出小文件的话可以直接使用想phpMyAdmin这样的工具。
|
||
|
||
mysql -u USER_NAME –xml -e 'SELECT * FROM table_name' > table_name.xml
|
||
|
||
上面的例子中USER_NAME是数据库的用户名,table_name是待导出为xml文件的表名,table_name.xml是存放数据的xml文件
|
||
|
||
### 9. MySQL_pconnect是什么? 它和MySQL_connect有什么区别? ###
|
||
|
||
**Ans**: MySQL_pconnect()打开一个永久的数据库连接,这意味着数据库不是在每次页面加载的时候被打开,因此我们不能使用MySQL_close()来关闭一个永久的连接
|
||
|
||
MySQL_pconnect和MySQL_connect有一定的差别
|
||
|
||
和MySQL_pconnect不同,MySQL_connect在每次页面被加载的时候打开,并且可以使用MySQL_close()语句来关闭连接
|
||
|
||
### 10. 如何查看一个名为'mysql'的数据库中'user'表中的所有索引? ###
|
||
|
||
**Ans**: 可以使用下面的语句
|
||
|
||
mysql> show index from user;
|
||
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
|
||
| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
|
||
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
|
||
| user | 0 | PRIMARY | 1 | Host | A | NULL | NULL | NULL | | BTREE | | |
|
||
| user | 0 | PRIMARY | 2 | User | A | 4 | NULL | NULL | | BTREE | | |
|
||
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
|
||
2 rows in set (0.00 sec)
|
||
|
||
### 11. 什么是CSV表? ###
|
||
|
||
**Ans**: CSV是逗号分隔值的缩写,也称为字符分隔值。CSV表中存放纯文本和表格数据。
|
||
|
||
每一条记录使用具体的分隔符隔开(如逗号,分号,...),CSV表广泛的用来存放易于导入和导出的电话联系人,能够用来存放任何数量的纯文本。
|
||
|
||
以上就是这次要将的内容。我还会带来其他的有趣的文章,向往你们喜欢。连接到Tecmint继续关注我们,不要忘了在评论栏中留下你们的宝贵意见。
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: http://www.tecmint.com/mysql-advance-interview-questions/
|
||
|
||
译者:[译者ID](https://github.com/译者ID) 校对:[校对者ID](https://github.com/校对者ID)
|
||
|
||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](http://linux.cn/) 荣誉推出
|
||
|
||
[1]:http://www.tecmint.com/basic-mysql-interview-questions-for-database-administrators/
|
||
[2]:http://www.tecmint.com/10-mysql-database-interview-questions-for-beginners-and-intermediates/
|