Соединение Java NetBeans JDBC, работающее в режиме отладки, а не в режиме выполнения - PullRequest
2 голосов
/ 26 апреля 2011

Я создаю небольшой внутренний инструмент (непроизводственный код), который получает некоторые вещи из нашей базы данных MS SQL.Я хотел попробовать NetBeans 6.9.1, поэтому использую его.

У меня есть эта функция для подключения к БД, и у меня есть системный DSN для настройки FAND_DEV в качестве собственного клиента SQL.

private static Connection GetConnection() {
            Connection conn = null;
        try {            
            conn = DriverManager.getConnection("jdbc:odbc:FAND_DEV");
        } catch (SQLException ex) {
            Logger.getLogger(DAL.class.getName()).log(Level.SEVERE, null, ex);
        }

        return conn;
}

Когда я шагаю по коду в режиме отладки, все работает отлично.Я получаю ожидаемые данные из БД без проблем.

Однако, когда я пытаюсь запустить (Запустить основной проект в NetBeans), он вызывает исключение при подключении к БД.Любая помощь по этому вопросу будет принята с благодарностью.

java.sql.SQLException: [Microsoft][ODBC Driver Manager] Invalid string or buffer length
        at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6957)
        at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7114)
        at sun.jdbc.odbc.JdbcOdbc.SQLGetDataString(JdbcOdbc.java:3907)
        at sun.jdbc.odbc.JdbcOdbcResultSet.getDataString(JdbcOdbcResultSet.java:5698)
        at sun.jdbc.odbc.JdbcOdbcResultSet.getString(JdbcOdbcResultSet.java:354)
        at sun.jdbc.odbc.JdbcOdbcConnection.buildTypeInfo(JdbcOdbcConnection.java:1503)
        at sun.jdbc.odbc.JdbcOdbcConnection.initialize(JdbcOdbcConnection.java:381)
        at sun.jdbc.odbc.JdbcOdbcDriver.connect(JdbcOdbcDriver.java:174)
        at java.sql.DriverManager.getConnection(DriverManager.java:582)
        at java.sql.DriverManager.getConnection(DriverManager.java:207)
        at gosDbCopy.db.DAL.GetConnection(DAL.java:53)

1 Ответ

0 голосов
/ 26 апреля 2011

С MS SQL вы должны иметь возможность использовать JDBC вместо использования моста JDBC-ODBC. Однако причина может быть связана с этим . Причина может быть из-за типа данных, которые вы также возвращаете. Это , кажется, дает один пример этого.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...