DemoDataTruncation.java Source code

Java tutorial

Introduction

Here is the source code for DemoDataTruncation.java

Source

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();
        }
    }
}