org.kiwiproject.jdbc.postgres.KiwiPostgres Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kiwi Show documentation
Show all versions of kiwi Show documentation
Kiwi is a utility library. We really like Google's Guava, and also use Apache Commons.
But if they don't have something we need, and we think it is useful, this is where we put it.
package org.kiwiproject.jdbc.postgres;
import lombok.experimental.UtilityClass;
import org.postgresql.util.PGobject;
import java.sql.SQLException;
/**
* Utility functions related to Postgres DBs.
*/
@UtilityClass
public class KiwiPostgres {
/**
* The Postgres "json" type.
*/
public static final String JSON_TYPE = "json";
/**
* The Postgres "jsonb" type.
*/
public static final String JSONB_TYPE = "jsonb";
/**
* Creates a new {@link PGobject} of type {@link #JSON_TYPE} with the given JSON value.
*
* @param jsonValue the JSON value as a {@link String}
* @return a PGobject of type {@code json} with the given JSON string value
*/
public static PGobject newJSONObject(String jsonValue) {
return newPGobject(JSON_TYPE, jsonValue);
}
/**
* Creates a new {@link PGobject} of type {@link #JSONB_TYPE} with the given JSON value.
*
* @param jsonValue the JSON value as a {@link String}
* @return a PGobject of type {@code jsonb} with the given JSON string value
*/
public static PGobject newJSONBObject(String jsonValue) {
return newPGobject(JSONB_TYPE, jsonValue);
}
/**
* Creates a new {@link PGobject} of the specified type and with the given value.
*
* @param type the type of object, e.g., {@code json} or {@code jsonb}
* @param value the value as a String
* @return a new {@link PGobject}
* @implNote We are catching the {@link SQLException} thrown by {@link PGobject#setType(String)} and wrapping
* with an {@link IllegalStateException} since this should never happen, since that specific setter method simply
* sets an instance field.
*/
public static PGobject newPGobject(String type, String value) {
var pg = new PGobject();
pg.setType(type);
try {
pg.setValue(value);
} catch (SQLException e) {
throw new IllegalStateException(
"This should not have happened (we are setting value on the base PGobject)", e);
}
return pg;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy