com.landawn.abacus.type.AtomicLongType Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of abacus-common Show documentation
Show all versions of abacus-common Show documentation
A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.
/*
* Copyright (C) 2015 HaiYang Li
*
* 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 com.landawn.abacus.type;
import java.io.IOException;
import java.io.Writer;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.concurrent.atomic.AtomicLong;
import com.landawn.abacus.parser.SerializationConfig;
import com.landawn.abacus.util.CharacterWriter;
import com.landawn.abacus.util.IOUtil;
import com.landawn.abacus.util.N;
/**
*
* @author Haiyang Li
* @since 0.8
*/
public class AtomicLongType extends AbstractAtomicType {
public static final String ATOMIC_LONG = AtomicLong.class.getSimpleName();
AtomicLongType() {
super(ATOMIC_LONG);
}
/**
*
*
* @return
*/
@Override
public Class clazz() {
return AtomicLong.class;
}
/**
*
* @param rs
* @param columnIndex
* @return
* @throws SQLException the SQL exception
*/
@Override
public AtomicLong get(ResultSet rs, int columnIndex) throws SQLException {
return new AtomicLong(rs.getLong(columnIndex));
}
/**
*
* @param rs
* @param columnLabel
* @return
* @throws SQLException the SQL exception
*/
@Override
public AtomicLong get(ResultSet rs, String columnLabel) throws SQLException {
return new AtomicLong(rs.getLong(columnLabel));
}
/**
*
* @param stmt
* @param columnIndex
* @param x
* @throws SQLException the SQL exception
*/
@Override
public void set(PreparedStatement stmt, int columnIndex, AtomicLong x) throws SQLException {
stmt.setLong(columnIndex, (x == null) ? 0 : x.get());
}
/**
*
* @param stmt
* @param parameterName
* @param x
* @throws SQLException the SQL exception
*/
@Override
public void set(CallableStatement stmt, String parameterName, AtomicLong x) throws SQLException {
stmt.setLong(parameterName, (x == null) ? 0 : x.get());
}
/**
*
* @param x
* @return
*/
@Override
public String stringOf(AtomicLong x) {
return (x == null) ? null : String.valueOf(x.get());
}
/**
*
* @param str
* @return
*/
@Override
public AtomicLong valueOf(String str) {
return N.isNullOrEmpty(str) ? null : new AtomicLong(Long.parseLong(str));
}
/**
*
* @param writer
* @param x
* @throws IOException Signals that an I/O exception has occurred.
*/
@Override
public void write(Writer writer, AtomicLong x) throws IOException {
if (x == null) {
writer.write(NULL_CHAR_ARRAY);
} else {
IOUtil.write(writer, x.get());
}
}
/**
*
* @param writer
* @param x
* @param config
* @throws IOException Signals that an I/O exception has occurred.
*/
@Override
public void writeCharacter(CharacterWriter writer, AtomicLong x, SerializationConfig config) throws IOException {
if (x == null) {
writer.write(NULL_CHAR_ARRAY);
} else {
writer.write(x.get());
}
}
}