mysql面试题集合

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

MYSQL支持事务吗?

在缺省模式下,MYSQL是autocommit模式的,所有的数据库更新操作都会即时提交,所以在缺省情况下,mysql是不支持事务的。

但是如果你的MYSQL表类型是使用InnoDB Tables 或BDB tables的话,你的MYSQL就可以使用事务处理,使用SET AUTOCOMMIT=0就可以使MYSQL允许在非autocommit模式,在非autocommit模式下,你必须使用COMMIT来提交你的更改,或者用ROLLBACK 来回滚你的更改。

示例如下:

START TRANSACTION;

SELECT @A:=SUM(salary) FROM table1 WHERE type=1;

UPDATE table2 SET summmary=@A WHERE type=1;

COMMIT;

MYSQL相比于其他数据库有哪些特点?

MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQL AB公司,现在已经

被Sun公司收购,支持FreeBSD、Linux、MAC、Windows等多种操作系统

与其他的大型数据库例如Oracle、DB2、SQL Server等相比功能稍弱一些

1、可以处理拥有上千万条记录的大型数据

2、支持常见的SQL语句规范

3、可移植行高,安装简单小巧

4、良好的运行效率,有丰富信息的网络支持

5、调试、管理,优化简单(相对其他大型数据库)

介绍一下mysql的日期和时间函数

这里是一个使用日期函数的例子。下面的查询选择所有date_col 值在最后30 天内的记录。mysql> SELECT something FROM tbl_name

WHERE TO_DAYS(NOW()) – TO_DAYS(date_col) <= 30;

DAYOFWEEK(date)

返回date 的星期索引(1 = Sunday, 2 = Monday, ... 7 = Saturday)。索引值符合ODBC 的标准。

mysql> SELECT DAYOFWEEK(’1998-02-03');

-> 3

WEEKDAY(date)

返回date 的星期索引(0 = Monday, 1 = Tuesday, … 6 = Sunday):

mysql> SELECT WEEKDAY(’1998-02-03 22:23:00′);

-> 1

mysql> SELECT WEEKDAY(’1997-11-05′);

-> 2

DAYOFMONTH(date)

返回date 是一月中的第几天,范围为1 到31:

mysql> SELECT DAYOFMONTH(’1998-02-03′);

-> 3

DAYOFYEAR(date)

返回date 是一年中的第几天,范围为1 到366:

mysql> SELECT DAYOFYEAR(’1998-02-03′);

-> 34

MONTH(date)

返回date 中的月份,范围为 1 到12:

mysql> SELECT MONTH(’1998-02-03′);

-> 2

DAYNAME(date)

返回date 的星期名:

mysql> SELECT DAYNAME(”1998-02-05″);

-> …Thursday‟

MONTHNAME(date)

返回date 的月份名:

mysql> SELECT MONTHNAME(”1998-02-05″);

-> …February‟

QUARTER(date)

返回date 在一年中的季度,范围为 1 到4:

mysql> SELECT QUARTER(’98-04-01′);

-> 2

WEEK(date)

WEEK(date,first)

对于星期日是一周中的第一天的场合,如果函数只有一个参数调用,返回date 为一年的第几周,返回值范围为0 到53 (是的,可能有第53 周的开始)。两个参数形式的WEEK() 允许你指定一周是否以星期日或星期一开始,以及返回值为0-53 还是1-52。这里的一个表显示第二个参数是如何工作的:值含义

0 一周以星期日开始,返回值范围为0-53

1 一周以星期一开始,返回值范围为0-53

2 一周以星期日开始,返回值范围为1-53

3 一周以星期一开始,返回值范围为1-53 (ISO 8601)

mysql> SELECT WEEK(’1998-02-20′);

-> 7

mysql> SELECT WEEK(’1998-02-20′,0);

-> 7

mysql> SELECT WEEK(’1998-02-20′,1);

-> 8

mysql> SELECT WEEK(’1998-12-31′,1);

-> 53

注意,在版本4.0 中,WEEK(#,0) 被更改为匹配USA 历法。注意,如果一周是上一年的最后一周,当你没有使用2 或 3 做为可选参数时,MySQL 将返回0:

mysql> SELECT YEAR(’2000-01-01′), WEEK(’2000-01-01′,0);

-> 2000, 0

mysql> SELECT WEEK(’2000-01-01′,2);

-> 52

你可能会争辩说,当给定的日期值实际上是1999 年的第52 周的一部分时,MySQL 对WEEK() 函数应该返回52。我们决定返回0 ,是因为我们希望该函数返回“在指定年份

相关文档
最新文档