import java.sql.Connection;
import java.sql.DataTruncation;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.SQLWarning;
import java.sql.Statement;
public class DemoDataTruncation {
public static void displayError(DataTruncation dataTruncation) {
System.out.println("Data truncation error: ");
System.out.println(dataTruncation.getDataSize() + " bytes should have been ");
if (dataTruncation.getRead()) {
System.out.println("Read (Error:) ");
} else {
System.out.println("Written (Error:) ");
}
System.out.println(dataTruncation.getTransferSize()
+ " number of bytes of data actually transferred.");
}
public static void displayError(SQLWarning warning) {
while (warning != null) {
if (warning instanceof DataTruncation) {
displayError((DataTruncation) warning);
} else {
System.out.println(" Warning: " + warning.getMessage());
}
warning = warning.getNextWarning();
}
}
public static Connection getMySQLConnection() throws Exception {
String driver = "org.gjt.mm.mysql.Driver";
String url = "jdbc:mysql://localhost/databaseName";
String username = "root";
String password = "root";
Class.forName(driver);
return DriverManager.getConnection(url, username, password);
}
public static void main(String[] args) throws Exception {
Connection conn = getMySQLConnection();
Statement stmt = null;
try {
stmt = conn.createStatement();
stmt.executeUpdate("DELETE FROM animals_table");
displayError(stmt.getWarnings());
stmt.executeUpdate("INSERT INTO animals_table(id, name)"
+ "VALUES(1, 'NameLongerThanColumnLengthInDatabase')");
displayError(stmt.getWarnings());
} catch (DataTruncation dt) {
displayError(dt);
dt.printStackTrace();
} catch (SQLException se) {
System.out.println("Database error message: " + se.getMessage());
} catch (Exception e) {
e.printStackTrace();
} finally {
stmt.close();
conn.close();
}
}
}