package org.fanli.facade.user.util.typehandler;
|
|
import java.sql.CallableStatement;
|
import java.sql.PreparedStatement;
|
import java.sql.ResultSet;
|
import java.sql.SQLException;
|
|
import org.apache.ibatis.type.BaseTypeHandler;
|
import org.apache.ibatis.type.JdbcType;
|
import org.fanli.facade.user.entity.account.user.UserCustomSettings.UserSettingTypeEnum;
|
|
public class UserSettingTypeEnumHandler extends BaseTypeHandler<UserSettingTypeEnum> {
|
|
@Override
|
public UserSettingTypeEnum getNullableResult(ResultSet arg0, String arg1) throws SQLException {
|
String key = arg0.getString(arg1);
|
if (arg0.wasNull()) {
|
return null;
|
} else {
|
return UserSettingTypeEnum.valueOf(key);
|
}
|
}
|
|
@Override
|
public UserSettingTypeEnum getNullableResult(ResultSet arg0, int arg1) throws SQLException {
|
String key = arg0.getString(arg1);
|
if (arg0.wasNull()) {
|
return null;
|
} else {
|
// 根据数据库中的key值,定位SexEnum子类
|
return UserSettingTypeEnum.valueOf(key);
|
}
|
}
|
|
@Override
|
public UserSettingTypeEnum getNullableResult(CallableStatement arg0, int arg1) throws SQLException {
|
String key = arg0.getString(arg1);
|
if (arg0.wasNull()) {
|
return null;
|
} else {
|
// 根据数据库中的key值,定位SexEnum子类
|
return UserSettingTypeEnum.valueOf(key);
|
}
|
}
|
|
@Override
|
public void setNonNullParameter(PreparedStatement arg0, int arg1, UserSettingTypeEnum arg2, JdbcType arg3)
|
throws SQLException {
|
arg0.setString(arg1, arg2.name());
|
}
|
|
}
|