如何比较两个java sql日期,一个在列表中,另一个刚刚输入
我试过这里贴的许多问题。我仍然没有找到解决问题的办法 我想比较用户输入的日期,在我的android应用程序中,我将日期存储在如何比较两个java sql日期,一个在列表中,另一个刚刚输入,java,android,date,Java,Android,Date,我试过这里贴的许多问题。我仍然没有找到解决问题的办法 我想比较用户输入的日期,在我的android应用程序中,我将日期存储在ArrayList中 我不想将克隆存储到已保存的日期,所以我必须检查。我使用JavaSQLDate来避免时间部分 static List<DatefromTo> myList; myList = new ArrayList<Dateclassobject>(); i =myList.size(); for(int j = 1; j <= my
ArrayList
中
我不想将克隆存储到已保存的日期,所以我必须检查。我使用JavaSQLDate来避免时间部分
static List<DatefromTo> myList;
myList = new ArrayList<Dateclassobject>();
i =myList.size();
for(int j = 1; j <= myList.size(); j ++){
int results2 = myList.get(i).datefrom.compareTo(myList.get(j).datefrom);
if(results2 > 0 ){
Toast.makeText(getApplicationContext(),"First Date is after second",Toast.LENGTH_LONG).show();
}else if(results2 < 0){
Toast.makeText(getApplicationContext(), "Wrong", Toast.LENGTH_LONG).show();
}else if(results2 == 0){
Toast.makeText(getApplicationContext(),String.valueOf(myList.get(i).datefrom) + "------" + String.valueOf(myList.get(j).datefrom),Toast.LENGTH_LONG).show();
}else{
Toast.makeText(getApplicationContext(), "Hi", Toast.LENGTH_LONG).show();
}
}
下面是这个类Dateadd的全部代码,我在这里做所有的事情
import java.sql.Date;
import java.util.ArrayList;
import java.util.Calendar;
//import java.util.Date;
import java.util.List;
import android.app.Activity;
import android.app.DatePickerDialog;
import android.graphics.Color;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.DatePicker;
import android.widget.EditText;
import android.widget.TableLayout;
import android.widget.TableRow;
import android.widget.TextView;
import android.widget.Toast;
public class DateAdd extends Activity {
private Button buttonsubmit;
DatePickerDialog dpdfrom, dpdto;
Date dtFrom, dtTo;
long milisto, milisfrom, days, diff;
int i;
Button delete;
TableLayout stk;
TextView tvadd, tvadd2, tvadd3, tvfrompick, tvtopick, t1v;
String abc;
DatefromTo datefromto, dtFT;
int listSize;
int mYearfrom, mMonthfrom, mDayfrom, mYearto, mMonthto, mDayto;
static List<DateClassObject> myList;
Calendar from; // get the from date from user and store here
Calendar to; // get the to date from user and store here
EditText et;
String datetoday, difference, string1, string2;
Long bringto, bringfrom, between;
boolean wrong;
boolean entryremover;
// boolean yrfm , mnfm , dyfm , yrto , mnto , dyto;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.dateadd);
from = Calendar.getInstance();
to= Calendar.getInstance();
final Calendar c = Calendar.getInstance();
mYearfrom = c.get(Calendar.YEAR);
mMonthfrom = c.get(Calendar.MONTH);
mDayfrom = c.get(Calendar.DAY_OF_MONTH);
mYearto = c.get(Calendar.YEAR);
mMonthto = c.get(Calendar.MONTH);
mDayto = c.get(Calendar.DAY_OF_MONTH);
buttonsubmit = (Button) findViewById(R.id.buttonsubmit);
et = (EditText) findViewById(R.id.et);
// tvspecial = (TextView) findViewById(R.id.tvspecial);
tvfrompick = (TextView) findViewById(R.id.tvfrompick);
tvtopick = (TextView) findViewById(R.id.tvtopick);
myList = new ArrayList<DateClassObject>();
i = (myList.size()-1);
init();
if (entryremover == true) {
delete.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
myList.remove(dtFT);
}
});
}
buttonsubmit.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
dtFT = new DatefromTo(from,to);
if(from.before(to)){
myList.add(dtFT);
AddEntry();
}
for(int j = 0; j < myList.size(); j ++){ //Note. you've written,
//for(int j = 1; j <= myList.size(); j ++) , ArrayList index start from 0. you'll miss the first element. I hope it helps you in the future
Calendar dateFrom = myList.get(j).dateFrom;
Calendar dateTo = myList.get(j).dateTo;
if(isSameDay(from, dateFrom) && isSameDay(to, dateTo)){ // checking same period allready exists
Toast.makeText(getApplicationContext(),
"Already exist",
Toast.LENGTH_LONG).show();
}
else{
// if it does not exists, I assume that you want to add it your arrayList
myList.add(new DatefromTo(from, to));
}
t1v.setText((myList.get(j).dateFrom
+ "\n" + myList.get(j).dateTo + "\n"));
}
tvfrompick.setText("");
tvtopick.setText("");
}
});
tvfrompick.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dpdfrom.show();
}
});
tvtopick.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dpdto.show();
}
});
dpdfrom = new DatePickerDialog(this,
new DatePickerDialog.OnDateSetListener() {
@Override
public void onDateSet(DatePicker view, int year,
int monthOfYear, int dayOfMonth) {
tvfrompick.setText(dayOfMonth + "-" + monthOfYear + 1
+ "-" + year);
mDayfrom = dayOfMonth;
mMonthfrom = (monthOfYear);
mYearfrom = year;
// dtFrom = new Date(mYearfrom - 1900, mMonthfrom,mDayfrom);
from.set(mYearfrom, mMonthfrom,
mDayfrom);
}
}, mYearfrom, mMonthfrom, mDayfrom);
dpdto = new DatePickerDialog(this,
new DatePickerDialog.OnDateSetListener() {
@SuppressWarnings({ "deprecation", "deprecation" })
@Override
public void onDateSet(DatePicker view, int year,
int monthOfYear, int dayOfMonth) {
tvtopick.setText(dayOfMonth + "-" + monthOfYear + 1
+ "-" + year);
mDayto = dayOfMonth;
mMonthto = (monthOfYear);
mYearto = year;
// dtTo = new Date((mYearto - 1900), mMonthto, mDayto);
to.set( mYearto, mMonthto, mDayto);
}
}, mYearto, mMonthto, mDayto);
}
public boolean isSameDay(Calendar cal1, Calendar cal2) {
if (cal1 == null || cal2 == null) {
throw new IllegalArgumentException("null");
}
return (cal1.get(Calendar.ERA) == cal2.get(Calendar.ERA) &&
cal1.get(Calendar.YEAR) == cal2.get(Calendar.YEAR) &&
cal1.get(Calendar.DAY_OF_YEAR) == cal2.get(Calendar.DAY_OF_YEAR));
}
public void init() {
stk = (TableLayout) findViewById(R.id.table_main);
TableRow tbrow0 = new TableRow(this);
TextView tv0 = new TextView(this);
tv0.setText("From");
tv0.setTextColor(Color.WHITE);
tv0.setPadding(20, 10, 20, 10);
tbrow0.addView(tv0);
TextView tv1 = new TextView(this);
tv1.setText(" To " + myList.size());
tv1.setTextColor(Color.WHITE);
tv1.setPadding(20, 10, 20, 10);
tv1.getPaddingLeft();
tbrow0.addView(tv1);
// Button tv2 = new Button(this);
// tv2.setText("Delete ");
// tv2.getPaddingLeft();
// //tv2.setTextColor(Color.WHITE);
// tbrow0.addView(tv2);
stk.addView(tbrow0);
}
public void AddEntry() {
entryremover = true;
TableRow tbrow = new TableRow(this);
t1v = new TextView(this);
// t1v.setText("From" + i);
myList.get(myList.size() - 1);
t1v.setTextColor(Color.WHITE);
t1v.setGravity(Gravity.CENTER);
t1v.setPadding(20, 10, 20, 10);
tbrow.addView(t1v);
delete = new Button(this);
delete.setText("Delete");
delete.setTextColor(Color.WHITE);
delete.setGravity(Gravity.CENTER);
delete.setPadding(20, 10, 20, 10);
tbrow.addView(delete);
stk.addView(tbrow);
}
public void removeEntry() {
}
}
import java.sql.Date;
导入java.util.ArrayList;
导入java.util.Calendar;
//导入java.util.Date;
导入java.util.List;
导入android.app.Activity;
导入android.app.DatePickerDialog;
导入android.graphics.Color;
导入android.os.Bundle;
导入android.view.Gravity;
导入android.view.view;
导入android.view.view.OnClickListener;
导入android.widget.Button;
导入android.widget.DatePicker;
导入android.widget.EditText;
导入android.widget.TableLayout;
导入android.widget.TableRow;
导入android.widget.TextView;
导入android.widget.Toast;
公共类DateAdd扩展活动{
私人按钮提交;
DatePickerDialog dpdfrom,dpdto;
日期dtFrom,dtTo;
长毫米,毫米从,天,不同;
int i;
按钮删除;
表格布局stk;
文本视图tvadd、tvadd2、tvadd3、tvfrompick、tvtopick、t1v;
字符串abc;
DatefromTo-DatefromTo,dtFT;
int列表大小;
int mYearfrom、mMonthfrom、mDayfrom、mYearto、mMonthto、mDayto;
静态列表;
日历起始日期;//从用户处获取起始日期并存储在此处
日历到;//从用户处获取到日期并存储在此处
编辑文本;
字符串datetoday、difference、string1、string2;
长带,从中间带;
布尔错误;
布尔入口移除器;
//布尔yrfm,mnfm,dyfm,yrto,mnto,dyto;
@凌驾
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.dateadd);
from=Calendar.getInstance();
to=Calendar.getInstance();
最终日历c=Calendar.getInstance();
mYearfrom=c.get(日历年);
monthfrom=c.get(日历月);
mDayfrom=c.get(日历、日期、月份);
mYearto=c.get(日历年);
monthto=c.get(日历月);
mDayto=c.get(日历日/月);
ButtonsSubmit=(Button)findViewById(R.id.ButtonsSubmit);
et=(EditText)findViewById(R.id.et);
//TVSecial=(TextView)findViewById(R.id.TVSecial);
tvfrompick=(TextView)findViewById(R.id.tvfrompick);
tvtopick=(TextView)findViewById(R.id.tvtopick);
myList=新的ArrayList();
i=(myList.size()-1);
init();
if(entryremover==true){
delete.setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
myList.remove(dtFT);
}
});
}
ButtonsSubmit.setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
dtFT=新日期fromto(from,to);
如果(从之前到){
myList.add(dtFT);
加法();
}
对于(int j=0;j //对于(int j=1;j使用日历而不是日期。(对我来说更容易,因为我在我正在做的项目中找到了你想要的大部分内容)
编辑:
好的,我已经对您的按钮单击做了一些更改,在if语句中添加for循环。如果我假设正确,则仅当fromDate不在toDate之前并且不是重复条目时,您才希望添加到arraylist
buttonsubmit.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
if(from.before(to)){
boolean alreadyExists = false;
for(int j = 0; j < myList.size(); j ++){
Calendar dateFrom = myList.get(j).dateFrom;
Calendar dateTo = myList.get(j).dateTo;
if(isSameDay(from, dateFrom) && isSameDay(to, dateTo)){ // checking same period allready exists
alreadyExists = true;
break;
}
}
if (alreadyExists){
Toast.makeText(getApplicationContext(),
"Already exist",
Toast.LENGTH_LONG).show();
}
else{
myList.add(new DateClassObject(from, to));
}
}
tvfrompick.setText("");
tvtopick.setText("");
}
});
buttonsubmit.setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
如果(从之前到){
布尔值alreadyExists=false;
对于(int j=0;j
至于您在代码中编写的删除按钮myList.remove(dtFT);
。删除方法将数组列表中的位置作为参数(整数值)。myList.remove(2)
从列表中删除第二个元素。因此,找出一些方法来获取要删除的元素的位置。这是一个艰难的过程
首先,该类确实有一天中的某个时间,但假装没有。作为java.util.Date的子类,它继承了一天中的某个时间,但将该时间设置为零值(您可以将其视为午夜)。引用文档:
为了符合SQL日期的定义,必须通过将小时、分钟、秒和毫秒设置为零来“规范化”java.SQL.DATE实例包装的毫秒值
此外,一天中的时间是UTC时区,所以如果你比较一个地区的日期时间值,比如说Montréal,那么你就有问题了
这些只是避免使用java.util.Date/.Calendar、java.sql.Date和SimpleDataFormat类的几个原因。它们是与java捆绑的库中最薄弱的领域之一
半开
处理时间跨度的一个关键想法
List<DateClassObject> myList = new ArrayList<>();
Calendar from = // get the from date from user and store here
Calendar to = // get the to date from user and store here
//to check 'from' is after 'to'
if(from.after(to)){
// Do your operation
}
for(int j = 0; j < myList.size(); j ++){ //Note. you've written, for(int j = 1; j <= myList.size(); j ++) , ArrayList index start from 0. you'll miss the first element. I hope it helps you in the future
Calendar dateFrom = myList.get(j).dateFrom;
Calendar dateTo = myList.get(j).dateTo;
if(isSameDay(from, dateFrom) && isSameDay(to, dateTo)){ // checking same period allready exists
// if it exists Do operation
}
else{
// if it does not exists, I assume, you want to add DateClassObject to your arrayList
myList.add(new DateClassObject(from, to));
}
}
public boolean isSameDay(Calendar cal1, Calendar cal2) {
if (cal1 == null || cal2 == null) {
throw new IllegalArgumentException("The dates must not be null");
}
return (cal1.get(Calendar.MONTH) == cal2.get(Calendar.MONTH) &&
cal1.get(Calendar.YEAR) == cal2.get(Calendar.YEAR) &&
cal1.get(Calendar.DAY_OF_MONTH) == cal2.get(Calendar.DAY_OF_MONTH));
}
public class DateClassObject {
public Calendar dateFrom;
public Calendar dateTo;
public Date difference;
public DateClassObject(Calendar dateFrom, Calendar dateTo) {
this.dateFrom = dateFrom;
this.dateTo = dateTo;
}
}
int day = datePicker.getDayOfMonth();
int month = datePicker.getMonth();
int year = datePicker.getYear();
Calendar from = Calendar.getInstance();
from.set(year, month, day);
buttonsubmit.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
if(from.before(to)){
boolean alreadyExists = false;
for(int j = 0; j < myList.size(); j ++){
Calendar dateFrom = myList.get(j).dateFrom;
Calendar dateTo = myList.get(j).dateTo;
if(isSameDay(from, dateFrom) && isSameDay(to, dateTo)){ // checking same period allready exists
alreadyExists = true;
break;
}
}
if (alreadyExists){
Toast.makeText(getApplicationContext(),
"Already exist",
Toast.LENGTH_LONG).show();
}
else{
myList.add(new DateClassObject(from, to));
}
}
tvfrompick.setText("");
tvtopick.setText("");
}
});
LocalDate earliest = new LocalDate( 2015 , 6 , 1 );
LocalDate latest = new LocalDate( 2015 , 7 , 1 );
LocalDate inputLocalDate = new LocalDate( 2015 , 5 , 15 );
if ( inputLocalDate.isBefore( earliest ) ) {
earliest = inputLocalDate ; // Extend left-side of date range to earlier date.
} else if ( inputLocalDate.isAfter( latest ) ) {
latest = inputLocalDate ; // Extend right-side of date range to later date.
} else {
// Else the input date is within the date range, inclusive ( Closed range '[]', rather than Half-Open '[)` ).
}