/*
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.skife.jdbi.v2;

import org.skife.jdbi.v2.tweak.Argument;

import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Timestamp;
import java.sql.Types;
import java.util.Date;

Binds a @{link Date) argument to a prepared statement. A Java Date is really a timestamp because it contains both a time and a date. If you need explicit binding for only time or only date, use SqlDateArgument or TimeArgument.
/** * Binds a @{link Date) argument to a prepared statement. A Java Date is really a timestamp because * it contains both a time and a date. If you need explicit binding for only time or only date, use * {@link SqlDateArgument} or {@link TimeArgument}. */
class JavaDateArgument implements Argument { private final Date value; JavaDateArgument(Date value) { this.value = value; } @Override public void apply(int position, PreparedStatement statement, StatementContext ctx) throws SQLException { if (value != null) { statement.setTimestamp(position, new Timestamp(value.getTime())); } else { statement.setNull(position, Types.TIMESTAMP); } } @Override public String toString() { return String.valueOf(value); } }