接下来,我们删除 \表中的 \列:
ALTER TABLE Person DROP COLUMN Birthday
Persons 表会成为这样: Id 1 2 3 LastName Adams Bush Carter FirstName John George Thomas Address Oxford Street Fifth Avenue Changan Street City London New York Beijing SQL 日期 当我们处理日期时,最难的任务恐怕是确保所插入的日期的格式,与数据库中日期列的格式相匹配。
只要数据包含的只是日期部分,运行查询就不会出问题。但是,如果涉及时间,情况就有点复杂了。
在讨论日期查询的复杂性之前,我们先来看看最重要的内建日期处理函数。
MySQL Date 函数
下面的表格列出了 MySQL 中最重要的内建日期函数:
函数 NOW() CURDATE() CURTIME() DATE() EXTRACT() DATE_ADD() DATE_SUB() DATEDIFF() 描述 返回当前的日期和时间 返回当前的日期 返回当前的时间 提取日期或日期/时间表达式的日期部分 返回日期/时间按的单独部分 给日期添加指定的时间间隔 从日期减去指定的时间间隔 返回两个日期之间的天数 DATE_FORMAT() 用不同的格式显示日期/时间 SQL Server Date 函数 下面的表格列出了 SQL Server 中最重要的内建日期函数:
函数 GETDATE() DATEPART() DATEADD() DATEDIFF() CONVERT() 描述 返回当前日期和时间 返回日期/时间的单独部分 在日期中添加或减去指定的时间间隔 返回两个日期之间的时间 用不同的格式显示日期/时间 SQL Date 数据类型 MySQL 使用下列数据类型在数据库中存储日期或日期/时间值:
? DATE - 格式 YYYY-MM-DD
? DATETIME - 格式: YYYY-MM-DD HH:MM:SS ? TIMESTAMP - 格式: YYYY-MM-DD HH:MM:SS ? YEAR - 格式 YYYY 或 YY
SQL Server 使用下列数据类型在数据库中存储日期或日期/时间值:
? DATE - 格式 YYYY-MM-DD
? DATETIME - 格式: YYYY-MM-DD HH:MM:SS ? SMALLDATETIME - 格式: YYYY-MM-DD HH:MM:SS ? TIMESTAMP - 格式: 唯一的数字
SQL 日期处理
如果不涉及时间部分,那么我们可以轻松地比较两个日期!
假设我们有下面这个 \表:
OrderId 1 2 ProductName computer printer OrderDate 2008-12-26 2008-12-26 3 4 electrograph telephone 2008-11-12 2008-10-19 现在,我们希望从上表中选取 OrderDate 为 \的记录。
我们使用如下 SELECT 语句:
SELECT * FROM Orders WHERE OrderDate='2008-12-26'
结果集:
OrderId 1 3 ProductName computer electrograph OrderDate 2008-12-26 2008-12-26 现在假设 \类似这样(请注意 \列中的时间部分):
OrderId 1 2 3 4 ProductName computer printer electrograph telephone OrderDate 2008-12-26 16:23:55 2008-12-26 10:45:26 2008-11-12 14:12:08 2008-10-19 12:56:10 如果我们使用上面的 SELECT 语句:
SELECT * FROM Orders WHERE OrderDate='2008-12-26'
那么我们得不到结果。这是由于该查询不含有时间部分的日期。
提示:如果您希望使查询简单且更易维护,那么请不要在日期中使用时间部分!
SQL NULL 值
如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新纪录或更新已有的记录。这意味着该字段将以 NULL 值保存。
NULL 值的处理方式与其他值不同。 NULL 用作未知的或不适用的值的占位符。
注释:无法比较 NULL 和 0;它们是不等价的。
SQL 的 NULL 值处理
请看下面的 \表:
Id 1 2 3 LastName Adams Bush Carter FirstName John George Thomas Address Fifth Avenue City London New York Beijing 假如 \表中的 \列是可选的。这意味着如果在 \列插入一条不带值的记录,\列会使用 NULL 值保存。
那么我们如何测试 NULL 值呢?
无法使用比较运算符来测试 NULL 值,比如 =, <, 或者 <>。
我们必须使用 IS NULL 和 IS NOT NULL 操作符。
SQL IS NULL
我们如何仅仅选取在 \列中带有 NULL 值的记录呢?
我们必须使用 IS NULL 操作符:
SELECT LastName,FirstName,Address FROM Persons WHERE Address IS NULL
结果集:
LastName Adams Carter FirstName John Thomas Address 提示:请始终使用 IS NULL 来查找 NULL 值。
SQL IS NOT NULL
我们如何选取在 \列中不带有 NULL 值的记录呢?
我们必须使用 IS NOT NULL 操作符:
SELECT LastName,FirstName,Address FROM Persons WHERE Address IS NOT NULL
结果集:
LastName Bush FirstName George Address Fifth Avenue SQL ISNULL()、NVL()、IFNULL() 和 COALESCE() 函数 请看下面的 \表:
P_Id 1 2 3 ProductName computer printer telephone UnitPrice 699 365 280 UnitsInStock 25 36 159 UnitsOnOrder 15 57 假如 \是可选的,而且可以包含 NULL 值。
我们使用如下 SELECT 语句:
SELECT ProductName,UnitPrice*(UnitsInStock+UnitsOnOrder) FROM Products
在上面的例子中,如果有 \值是 NULL,那么结果是 NULL。
微软的 ISNULL() 函数用于规定如何处理 NULL 值。
NVL(), IFNULL() 和 COALESCE() 函数也可以达到相同的结果。
在这里,我们希望 NULL 值为 0。
百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说综合文库SQL总结(6)在线全文阅读。
相关推荐: