sql查询中日期加减的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql查询中日期加减的问题相关的知识,希望对你有一定的参考价值。

在left join...on...中将一个日期对应的数据列和这个日期前一天对应的数据列匹配
比如

.....
left join
.....
on a.id=b.id and a.date=(b.date-1)
大概就是括号里的意思,用昨天的数据,和今天的数据组成两列进行环比。我知道括号里格式不对,正确的应该怎么写啊。
我用的是oracle

他们说的那个dateadd 不是oracle的函数。是sqlserver 的,你要前一天的
可以
SELECT SYSDATE-1 FROM DUAL 直接减一就是默认减一天。就算是1号 也会变成上个月的最后一天
参考技术A 写成on a.id=b.id and a.date=dateadd(dd,-1,b.date) 参考技术B --用dateadd函数。b.date减一天
on a.id=b.id and a.date=dateadd(day,-1,b.date)追问

显示

ORA-00904:"DAY":标识符无效

追答

select dateadd(DAY,-1,getdate()) as 昨天
/* 结果
昨天
-----------------------
2014-03-26 16:00:43.060

(1 row(s) affected)
*/

没问题,你用的什么数据库?

java 常用的日期加减和日期格式化工具类

  平时我们遇到日期的加减,感觉是相当麻烦的,以下是常用的日志加减的方法,包括日的加减、月的加减等,也包括了一些常用的日期格式化,这样在我们以后碰到日期加减的时候会省去很多麻烦,欢迎大神指正和吐槽:

  1   package bp.util;
  2 
  3 import java.text.ParseException;
  4 import java.text.SimpleDateFormat;
  5 import java.util.Calendar;
  6 import java.util.Date;
  7 
  8 public final class DateUtils
  9 {
 10     /**
 11      * 英文简写(默认)如:2010-12-01
 12      */
 13     public static String FORMAT_SHORT = "yyyy-MM-dd";
 14     /**
 15      * 英文简写(默认)如:2010-12-01
 16      */
 17     public static String FORMAT_DIY = "yyyy/MM/dd";
 18      
 19     /**
 20      * 英文全称  如:2010-12-01 23:15:06
 21      */
 22     public static String FORMAT_LONG = "yyyy-MM-dd HH:mm:ss";
 23      
 24     /**
 25      * 精确到毫秒的完整时间    如:yyyy-MM-dd HH:mm:ss.S
 26      */
 27     public static String FORMAT_FULL = "yyyy-MM-dd HH:mm:ss.S";
 28      
 29     /**
 30      * 中文简写  如:2010年12月01日
 31      */
 32     public static String FORMAT_SHORT_CN = "yyyy年MM月dd";
 33      
 34     /**
 35      * 中文全称  如:2010年12月01日  23时15分06秒
 36      */
 37     public static String FORMAT_LONG_CN = "yyyy年MM月dd日  HH时mm分ss秒";
 38      
 39     /**
 40      * 精确到毫秒的完整中文时间
 41      */
 42     public static String FORMAT_FULL_CN = "yyyy年MM月dd日  HH时mm分ss秒SSS毫秒";
 43  
 44     /**
 45      * 获得默认的 date pattern
 46      */
 47     public static String getDatePattern() {
 48         return FORMAT_LONG;
 49     }
 50     /**
 51      * 获得默认的 date
 52      */
 53     public static String getDatePatt() {
 54         return FORMAT_DIY;
 55     }
 56     public static String getDateShot() {
 57         return FORMAT_SHORT;
 58     }
 59     /**
 60      * 根据预设格式返回当前日期
 61      * @return
 62      */
 63     public static String getNow() {
 64         return format(new Date());
 65     }
 66      
 67     public static Date getDate(){
 68         return new Date();
 69     }
 70     /**
 71      * 根据用户格式返回当前日期
 72      * @param format
 73      * @return
 74      */
 75     public static String getNow(String format) {
 76         return format(new Date(), format);
 77     }
 78  
 79      
 80     /**
 81      * 使用预设格式格式化日期
 82      * @param date
 83      * @return
 84      */
 85     public static String format(Date date) {
 86         return format(date, getDatePattern());
 87     }
 88     /**
 89      * 使用预设格式格式化日期
 90      * @param date
 91      * @return
 92      */
 93     public static String format1(Date date) {
 94         return format(date, getDatePatt());
 95     }
 96     
 97     public static String format2(Date date) {
 98             return format(date, getDateShot());
 99         }
100     /**
101      * 使用用户格式格式化日期
102      * @param date 日期
103      * @param pattern 日期格式
104      * @return
105      */
106     public static String format(Date date, String pattern) {
107         String returnValue = "";
108         if (date != null) {
109             SimpleDateFormat df = new SimpleDateFormat(pattern);
110             returnValue = df.format(date);
111         }
112         return (returnValue);
113     }
114  
115     /**
116      * 使用预设格式提取字符串日期
117      * @param strDate 日期字符串
118      * @return
119      */
120     public static Date parse(String strDate) {
121         return parse(strDate, getDatePattern());
122     }
123  
124     public static Date parseShot(String strDate) {
125             return parse(strDate, getDateShot());
126     }
127     
128     /**
129      * 使用用户格式提取字符串日期
130      * @param strDate 日期字符串
131      * @param pattern 日期格式
132      * @return
133      */
134     public static Date parse(String strDate, String pattern) {
135         SimpleDateFormat df = new SimpleDateFormat(pattern);
136         try {
137             return df.parse(strDate);
138         } catch (ParseException e) {
139             e.printStackTrace();
140             return null;
141         }
142     }
143  
144     /**
145      * 在日期上增加数个整月
146      * @param date 日期
147      * @param n 要增加的月数
148      * @return
149      */
150     public static Date addMonth(Date date, int n) {
151         Calendar cal = Calendar.getInstance();
152         cal.setTime(date);
153         cal.add(Calendar.MONTH, n);
154         return cal.getTime();
155     }
156  
157     /**
158      * 在日期上增加天数
159      * @param date 日期
160      * @param n 要增加的天数
161      * @return
162      */
163     public static Date addDay(Date date, int n) {
164         Calendar cal = Calendar.getInstance();
165         cal.setTime(date);
166         cal.add(Calendar.DATE, n);
167         return cal.getTime();
168     }
169  
170     /**
171      * 获取时间戳
172      */
173     public static String getTimeString() {
174         SimpleDateFormat df = new SimpleDateFormat(FORMAT_FULL);
175         Calendar calendar = Calendar.getInstance();
176         return df.format(calendar.getTime());
177     }
178  
179     /**
180      * 获取日期年份
181      * @param date 日期
182      * @return
183      */
184     public static String getYear(Date date) {
185         return format(date).substring(0, 4);
186     }
187      
188     /**
189      * 按默认格式的字符串距离今天的天数
190      * @param date 日期字符串
191      * @return
192      */
193     public static int countDays (String date) {
194         long t = Calendar.getInstance().getTime().getTime();
195         Calendar c = Calendar.getInstance();
196         c.setTime(parse(date));
197         long t1 = c.getTime().getTime();
198         return (int)(t/1000 - t1/1000)/3600/24;
199     }
200      
201     /**
202      * 按用户格式字符串距离今天的天数
203      * @param date 日期字符串
204      * @param format 日期格式
205      * @return
206      */
207     public static int countDays (String date, String format) {
208         long t = Calendar.getInstance().getTime().getTime();
209         Calendar c = Calendar.getInstance();
210         c.setTime(parse(date, format));
211         long t1 = c.getTime().getTime();
212         return (int)(t/1000 - t1/1000)/3600/24;
213     }
214     
215     /**
216      * 
217     * @Title: getBackTime 
218     * @Description: TODO(这里用一句话描述这个方法的作用) 
219     * @param @param timestr
220     * @param @return    设定文件 
221     * @return Date    返回类型 
222     * @throws
223      */
224     public static Date getBackTime(String timestr) {
225         Date curTime = new Date();
226         Date startTime = DateUtils.addMonth(curTime, -12);
227         if (timestr.equals("ONEYEAE")) {
228         } else if (timestr.equals("TWOYEAR")) {
229             startTime = DateUtils.addMonth(curTime, -12 * 2);
230         } else if (timestr.equals("ALL")) {
231             startTime = null;
232         }
233         return startTime;
234     }  
235 }

 

以上是关于sql查询中日期加减的问题的主要内容,如果未能解决你的问题,请参考以下文章

java 常用的日期加减和日期格式化工具类

SQL语句问题(关于日期加减与字段加减)

如何用js进行日期的加减

js获取文本框的日期,并且进行加减,以得到另一个日期

sql里日期怎么加减

sql里日期怎么加减