MySQL查詢年齡,有以下幾種方式:
我們提供的服務(wù)有:網(wǎng)站制作、成都網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、烏蘭ssl等。為上千企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學管理、有技術(shù)的烏蘭網(wǎng)站制作公司
條件:表中針對年齡的字段名假如為age字段(其他名字也可以)
查詢單條記錄,通過已有字段信息匹配查詢,如姓名name為“張三”或者id為1
SELECT age FROM?表名?where name="張三";
SELECT age FROM?表名?where id = 1;
查詢所有記錄,直接獲取所有age字段數(shù)據(jù)
SELECT age FROM?表名;
總之:所有查詢本質(zhì)都一樣
SELECT之后跟目標字段,如果需要表中所有信息,使用“*”代替字段名
條件篩選數(shù)據(jù),沒有條件就不用使用where篩選,否則使用where結(jié)合條件篩選
在Mysql中計算年齡:
SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(birthday)), '%Y')+0 AS age FROM 表名;
以前使用mysql不是很多,對mysql的函數(shù)也不是很熟悉,遇到這個問題第一時間百度搜索,搜索到這兩種方法,這兩種方法是排在百度第一條的博客。
方法一,作者也說出了缺陷,就是當日期為未來日期時結(jié)果為0,而不是負數(shù);這里使用了5個函數(shù)和兩個運算符。
方法二,解決了方法一為負數(shù)的問題,但看起來更復(fù)雜;這里使用了6個函數(shù)和3個運算符。
看了這篇貼子后,我就暈了,怎么會這么復(fù)雜,以前用Sql Server很簡單就可以了。我堅信一定有簡單高效的方法。很快就找到了根據(jù)以上方法改良后的方法。
改良后的方法一,少了一個函數(shù)和一個運算符,當日期為未來日期時計算結(jié)果還是為0;
改良后的方法二,還是6個函數(shù)和3個運算符,看起來簡單些;取日期的右邊五位,當日期格式為‘2013-01-01’時取到的是‘01-01’,沒有問題;當日期格式為‘2013-1-1’縮寫格式時,取右邊的五位取出的是‘3-1-1’,會導(dǎo)致出錯。
然后自己根據(jù)MYSQL的幫助文檔中的日期函數(shù)想到了第三種方法:
取生日和當前日期之前的天數(shù)除以一年的實際天數(shù)(365天5小時48分46秒),然后取整。這樣只用了三個函數(shù)和一個運算符就搞定了。
然后,很快在國外網(wǎng)站找到了第四種方法:
這種方法只用了兩個函數(shù)就搞定了,應(yīng)該是最佳方法了。
測試了一下以上四種方法,假如當前日期為'2017-1-13',當生日為‘2013-1-14’時,還差一天就要過生日了,離4歲只 差一天了,結(jié)果還是3歲,感覺不是很合理;把方法三改造一下,四舍五入得到方法五:
這樣計算出的年齡離實際的周歲最接近了,但可能方法四是最符合年齡定義的了。
SqlServer中通過出生日期計算年齡可用year函數(shù)。
有student表,數(shù)據(jù)如下,其中birthday列為生日列:要計算每個人的年齡,可用如下語句:select?*,year(getdate())-year(birthday)?age?from?student3、查詢結(jié)果如下,年齡計算結(jié)果出現(xiàn):
數(shù)據(jù)庫索引:
資數(shù)據(jù)索引的觀念由來已久,就像是一本書的目錄一樣,也算是索引的一種。只是索引的分類較廣,例如車牌、身份證字號、條碼等,都是一個索引的號碼,當我們看到號碼時,可以從號碼中看出其中的端倪,若是要找的人、車或物品,也只要提供相關(guān)的號碼,即可迅速查到正確的人事物。
另外,索引跟域有著相應(yīng)的關(guān)系,索引即是由域而來,其中域有所謂的關(guān)鍵域(Key Field),該域具有唯一性,即其值不可重復(fù),且不可為"空值(null)"。例如:在合并數(shù)據(jù)時,索引就是附加域數(shù)據(jù)之指向性用途。故此索引為不可重復(fù)性且不可為空。