mysql面试题集合
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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 ,是因为我们希望该函数返回“在指定年份