org.jdbcdslog.MySqlRdbmsSpecifics Maven / Gradle / Ivy
package org.jdbcdslog;
import java.sql.Time;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* RDBMS specifics for the MySql DB.
*
* @author ShunLi
*/
public class MySqlRdbmsSpecifics implements RdbmsSpecifics {
public MySqlRdbmsSpecifics() {
super();
}
public String formatParameter(Object object) {
if (object == null) {
return "null";
} else if (object instanceof String) {
String text = LogUtils.replaceEach(
(String) object,
new String[] { "\\", "$", "'", "\"", "\r", "\n", "\t" },
new String[] { "\\\\\\\\", "\\$", "\\\\'", "\\\\\"", "\\\\r", "\\\\n", "\\\\t" });
// handle Matcher's appendReplacement method special characters: \ and $
// handle mysql sql statment's special characters,like ' and " and \ and \r,\n,\t
// TODO only handle % and _ when use like statement. later processing.
return "'" + text + "'";
} else if (object instanceof Timestamp) {
return "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(object) + "'";
} else if (object instanceof Time) {
return "'" + new SimpleDateFormat("HH:mm:ss").format(object) + "'";
} else if (object instanceof Date) {
return "'" + new SimpleDateFormat("yyyy-MM-dd").format(object) + "'";
} else if (object instanceof Boolean) {
return ((Boolean) object).booleanValue() ? "'1'" : "'0'";
} else {
return object.toString();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy