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 ; |