1 MySQL Date 函数
函数 | 描述 | 在数据库中的存储格式 |
---|---|---|
now() | 返回当前的日期和时间 | |
curdate | 返回当前的日期 | |
curtime | 返回当前的时间 | |
date | 提取日期或日期/时间表达式的日期部分 | YYYY-MM-DD |
extract | 返回日期/时间的单独部分 | |
date_add() | 向日期添加指定的时间间隔 | |
date_sub() | 从日期减去指定的时间间隔 | |
datediff() | 返回两个日期之间的天数 | |
date_format() | 用不同的格式显示日期/时间 |
2 SQL server Date函数
函数 | 描述 |
---|---|
getdate() | 返回当前的日期和时间 |
datepart() | 返回日期/时间的单独部分 |
dateadd() | 在日期中添加或减去指定的时间间隔 |
datediff() | 返回两个日期之间的时间 |
convert() | 用不同的格式显示日期/时间 |
3 SQL null值和not null 值
null 值代表遗漏的未知数据。
注释:无法比较 null 和 0;它们是不等价的。
函数 | 描述 |
---|---|
ISNULL() | |
NVL() | |
IFNULL() | |
COALESCE() |
4 SQL Aggregate函数
SQL Aggregate 函数计算从列表中取得的值,返回一个单一的值。
函数 | 描述 |
---|---|
AVG() | 返回平均值 |
count() | 返回行数 |
first() | 返回第一个记录的值 |
last() | 返回最后一个记录的值 |
max() | 返回最大值 |
min() | 返回最小值 |
sum() | 返回综合 |
4.1 语法
4.1.1 avg()
avg()语法
selecct avg(column_name) from table_name
4.1.2 count()
count(column_name)语法:
count(column_name)函数返回指定列的值得数目(null不计入)
select count(column_name) from table_name;
count(*)语法:
count(*)函数返回表中的记录数:
select count(*) from table_name;
count(distinct column_name)语法
count(distinct column_name)函数返回指定列的不同值得数目:
select count(distinct column_name) from table_name;
注释:count(distinct) 适用于oracle和 MSSQL,但是无法用于 MSAccess。
4.4.3 first() 函数
first() 函数返回指定的列中第一个记录的值。
first() 语法
select first(column_name) from table_name;
注释:只有 MS Access 支持 first() 函数。
SQL server、MySQL 和 oracle 中的 SQL first() 工作区
SQL server语法:
select top 1 column_name from table_name
order by column_name ASC;
MySQL语法:
select column_name from table_name
order by column_name asc
limit 1;
oracle语法:
select column_name from table_name
ordrt by column_name asc
where rownum<=1;
4.1.4 last() 函数
last() 函数返回指定的列中最后一个记录的值。
last() 语法
select last(column_name) from table_name;
注释:只有MS Access 支持 last() 函数。
SQL server、MySQL 和 oracle 中的 SQL last() 工作区
SQL server 语法:
select top 1 column_name from table_name
order by column_name desc;
mysql 语法:
select column_name from table_name
order by column_name desc
limit 1;
oracle 语法:
select column_name from table_name
order by column_name desc
where rownum <= 1;
4.4.5 max()、min() 和 sum() 函数
max() 返回指定列的最大值。
min() 返回指定列的最小值。
sum() 返回数值列的总数。
max() 语法
select max(column_name) from table_name;
min() 语法
select min(column_name) from table_name
sun() 语法
select sum(column_name) from table_name;
4.2 group by 语句
group by 语句可结合一些聚合函数来使用,根据一个或多个列对结果集进行分组。
group by 语法
select column_name,aggregate_function(column_name)
from table_name
where column_name operator value
group by column_name;
4.3 having 子句
在 SQL 中增加 having 子句原因是,where关键字无法与聚合函数一起使用。
having 子句可以让我们筛选分组后的各组数据。
having 语法
SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name
HAVING aggregate_function(column_name) operator value;
5 SQL Scalar 函数
SQL scalar 函数基于输入值,返回一个单一的值。
函数 | 描述 |
---|---|
ucase() | 将某个字段转换成大写 |
lcase() | 将某个字段转换为小写 |
mid() | 从某个文本字段提取字符,MySQL中使用 |
substring(字段,1,end) | 从某个文本字段提取字符 |
len() | 返回某个文本字段的长度 |
round() | 对某个字段的显示方式 |
now() | 返回当前的系统日期和时间 |
format() | 格式化某个字段的显示方式 |