利用SQL计算生日所属的星座
创始人
2024-07-22 08:30:38
0

中午正好吃完饭,休息,看到QQ群里面发了一个问题,说给你一个没有年份的日期,算出这个日期所属的星座;起初刚开始的第一个想法就是取星座的开始和起始时间来做区间的比对,得到所在区间,就知道星座了!但后来想想,除了时间区间的比对,有没有其它的方法?

想来想去,试着用数字做比较看看(最后写完才觉得这个本质上和日期做比对没有什么区别);因为星座的时间区间段是固定的,不会有重复的,那么我可以把时间转换成数字,例如水瓶座是1/20到2/18,那我可以转换成120到218,但随之而来的就有一个问题了,例如今天这个日期,3月4号,由于转换成数字后会变成34(应该是304),中间少了个0,怎么都找不到区间,总是计算不对,最后只能改变一下将时间转换为数字的方法了!

  1. SELECT @NowDate = (CAST(MONTH(@Birthday) AS VARCHAR(10)) + CAST((CASE WHEN DAY(@Bir  
  2. thday) < 10  THEN '0' + CAST(DAY(@Birthday) AS VARCHAR(10)) ELSE CAST(DAY(@Birthday)   
  3. AS VARCHAR(10)) END) AS VARCHAR(10))); 

这个计算星座的方法,最麻烦的就是在前期的日期转换上,时间转好了,其它的就好办了,做数字区间的对比吧,就能得到你想要的星座了!
 

  1. /*    
  2.  星座     日期(公历)    英文名     
  3.  魔羯座 (12/22 - 01/19) Capricorn  
  4.  水瓶座 (01/20 - 02/18) Aquarius     
  5.  双鱼座 (02/19 - 03/20) Pisces     
  6.  牡羊座 (03/21 - 04/20) Aries     
  7.  金牛座 (04/21 - 05/20) Taurus     
  8.  双子座 (05/21 - 06/21) Gemini     
  9.  巨蟹座 (06/22 - 07/22) Cancer     
  10.  狮子座 (07/23 - 08/22) Leo     
  11.  处女座 (08/23 - 09/22) Virgo     
  12.  天秤座 (09/23 - 10/22) Libra     
  13.  天蝎座 (10/23 - 11/21) Scorpio     
  14.  射手座 (11/22 - 12/21) Sagittarius    
  15. */    
  16.  DECLARE @TABLE TABLE   
  17.  (    
  18.      name_zh VARCHAR(128),    
  19.      name_en VARCHAR(128),    
  20.      s_time INT,    
  21.      o_time INT   
  22.  );    
  23.  DECLARE @NowDate INT;    
  24.  DECLARE @Birthday DATETIME;    
  25.  SET @Birthday = GETDATE();    
  26.  SELECT @NowDate = (CAST(MONTH(@Birthday) AS VARCHAR(10)) + CAST((CASE WHEN DAY(@Birthday) < 10  THEN '0' + CAST(DAY(@Birthday) AS VARCHAR(10)) ELSE CAST(DAY(@Birthday) AS VARCHAR(10)) END) AS VARCHAR(10)));    
  27.  INSERT INTO    
  28.      @TABLE   
  29.  VALUES   
  30.      ('魔羯座' ,'Capricorn' ,1222 ,119),    
  31.      ('水瓶座' ,'Aquarius' ,120 ,218),    
  32.      ('双鱼座' ,'Pisces' ,219 ,320),    
  33.      ('牡羊座' ,'Aries' ,321 ,420),    
  34.      ('金牛座' ,'Taurus' ,421 ,520),    
  35.      ('双子座' ,'Gemini' ,521 ,621),    
  36.      ('巨蟹座' ,'Cancer' ,622 ,722),    
  37.      ('狮子座' ,'Leo' ,723 ,822),    
  38.      ('处女座' ,'Virgo' ,823 ,922),    
  39.      ('天秤座' ,'Libra' ,923 ,1022),    
  40.      ('天蝎座' ,'Scorpio' ,1023 ,1121),    
  41.      ('射手座' ,'Sagittarius' ,1122 ,1221);    
  42.  SELECT     
  43.      name_zh,    
  44.      name_en,    
  45.      s_time,    
  46.      o_time    
  47.  FROM    
  48.      @TABLE    
  49.  WHERE    
  50.      @NowDate BETWEEN s_time AND o_time;
      

这个方法没有过细的去验证,可能会存在Bug或者性能上的损失,以后有时间会在进一步改写!

【编辑推荐】

  1. 如何让微软认识闰年的2月29日
  2. 查询表结构的SQL语句
  3. 使用SQL语句查询时间段
  4. 巧用SQL语句删除重复记录
  5. 判断字段是否存在的SQL语句写法

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...