1.計算年齡
如果你有一個人的生日而需要計算這個人的年齡,將下列語句中@dateofbirth替換為生日即可
代碼如下 復制代碼SELECT DATE_FORMAT (FROM_DAYS (TO_DAYS (now ()) - TO_DAYS (@dateofbirth)), '%Y') + 0;
2.計算兩個日期的差值
計算兩個日期的分,秒,小時和天數的差值,如果dt1和dt2的的格式是‘yyyy-mm-dd hh:mm:ss’,那麼兩個日期之間的秒數差值就是
代碼如下 復制代碼UNIX_TIMESTAMP ( dt2 ) - UNIX_TIMESTAMP ( dt1 )
3.顯示出現了N次的欄目的值
代碼如下 復制代碼SELECT id
FROM tbl
GROUP BY id
HAVING COUNT (*) = N;
4.計算兩個日期之間的工作日
計算兩個日期之間的工作日的最簡單方法是是一個含有d日期欄目和另一個標定了在已知年份中所有日期是否為休息日的欄目的日歷表,然後下面的查詢就是找到在Start和Stop兩個日期之間所有的工作日
代碼如下 復制代碼SELECT COUNT (*)
FROM calendar
WHERE d BETWEEN Start AND Stop
AND DAYOFWEEK (d) NOT IN (1,7)
AND holiday=0;
5.找到一個表的主鍵
代碼如下 復制代碼SELECT k.column_name
FROM information_schema.table_constraints t
JOIN information_schema.key_column_usage k
USING (constraint_name,table_schema,table_name)
WHERE t.constraint_type='PRIMARY KEY'
AND t.table_schema='db'
AND t.table_name='tbl'
6.查詢你的數據庫數據占用的總空間
代碼如下 復制代碼SELECT
table_schema AS 'Db Name',
Round ( Sum ( data_length + index_length ) / 1024 / 1024, 3 ) AS 'Db Size (MB)',
Round ( Sum ( data_free ) / 1024 / 1024, 3 ) AS 'Free Space (MB)'
FROM information_schema.tables
GROUP BY table_schema ;