Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Как работать с JDBC





· загрузить драйвер в память виртуальной машины;

· получить соединение (Connection) с базой данных;

· подготовить выражение-запрос (Statement);

· выполнить запрос;

· разобрать полученные данные (ResultSet)

import java.net.URL;import java.sql.*; class SimpleSelect { public static void main (String args[]) { String url = "jdbc:odbc:my-dsn"; String query = "SELECT * FROM emp"; try { // Загружаем драйвер моста jdbc-odbc Class.forName ("sun.jdbc.odbc.JdbcOdbcDriver"); DriverManager.setLogStream(System.out); // Пытаемся соединиться с драйвером. Идет поиск // хотя бы одного из зарегистированных // драйверов, который может обработать этот URL Connection con = DriverManager.getConnection (url, "my-user", "my-passwd"); // Если у нас не получится, то будет // сгенерировано исключение. Т.о., если мы до сюда дошли, // мы успешно соединились с URL // Посмотрим, какие замечания были сгенерированы // процедурой соединения. Выведем их. checkForWarning (con.getWarnings ()); // Получить объект DatabaseMetaData и отобразить // некоторую информацию об этом подключении DatabaseMetaData dma = con.getMetaData (); System.out.println("\nConnected to " + dma.getURL()); System.out.println("Driver " + dma.getDriverName()); System.out.println("Version " + dma.getDriverVersion()); System.out.println(""); // Создаем объект Statement, чтобы можно было // отсылать SQL-запросы к драйверу Statement stmt = con.createStatement (); // Отсылаем запрос, получаем объект ResultSet rs = stmt.executeQuery (query); // Показать все колонки и стороки из набора данных dispResultSet (rs); // Закрыть набор данных rs.close(); // Закрыть оператор stmt.close(); // Закрыть соединение con.close(); } catch (SQLException ex) { // Сгенерировалось исключение SQLException. Отловить его // и отобразить информацию об ошибке. Заметим, что может быть несколько // объектов ошибки, соединенных вместе в одну цепочку System.out.println ("\n*** Поймали SQLException ***\n"); while (ex!= null) { System.out.println ("SQLState: " + ex.getSQLState ()); System.out.println ("Сообщение: " + ex.getMessage ()); System.out.println ("Vendor: " + ex.getErrorCode ()); ex = ex.getNextException (); System.out.println (""); } } catch (java.lang.Exception ex) { // Получили ошибку другого типа. Распечатать ее. ex.printStackTrace (); }} //------------------------------------------------------------------//-------------------------------------------------------------------// dispResultSet// Отображает все колонки и строки в данном наборе данных//------------------------------------------------------------------- private static void dispResultSet (ResultSet rs) throws SQLException{ int i; // Получить ResultSetMetaData. Он нужен для // получения загловков колонок ResultSetMetaData rsmd = rs.getMetaData (); // Взять количество колонок в наборе данных int numCols = rsmd.getColumnCount (); // Показать шапку for (i=1; i<=numCols; i++) { if (i > 1) System.out.print(","); System.out.print(rsmd.getColumnLabel(i)); } System.out.println(""); // Показать все данные вплоть до конца набора данных boolean more = rs.next (); while (more) { // Для каждой колонки в цикле: получить // ее значение и показать его for (i=1; i<=numCols; i++) { if (i > 1) System.out.print(","); System.out.print(rs.getString(i)); } System.out.println(""); // Передвинуться на следующую строку набора данных more = rs.next (); }}}






Дата добавления: 2015-08-30; просмотров: 395. Нарушение авторских прав; Мы поможем в написании вашей работы!




Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...


Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...


ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

Шов первичный, первично отсроченный, вторичный (показания) В зависимости от времени и условий наложения выделяют швы: 1) первичные...

Предпосылки, условия и движущие силы психического развития Предпосылки –это факторы. Факторы психического развития –это ведущие детерминанты развития чел. К ним относят: среду...

Анализ микросреды предприятия Анализ микросреды направлен на анализ состояния тех со­ставляющих внешней среды, с которыми предприятие нахо­дится в непосредственном взаимодействии...

Различие эмпиризма и рационализма Родоначальником эмпиризма стал английский философ Ф. Бэкон. Основной тезис эмпиризма гласит: в разуме нет ничего такого...

Индекс гингивита (PMA) (Schour, Massler, 1948) Для оценки тяжести гингивита (а в последующем и ре­гистрации динамики процесса) используют папиллярно-маргинально-альвеолярный индекс (РМА)...

Методика исследования периферических лимфатических узлов. Исследование периферических лимфатических узлов производится с помощью осмотра и пальпации...

Studopedia.info - Студопедия - 2014-2026 год . (0.01 сек.) русская версия | украинская версия