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

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

Как работать с 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.Спрос и предложение на обеды в студенческой столовой описываются уравнениями: QD = 2400 – 100P; QS = 1000 + 250P   1.Спрос и предложение на обеды в студенческой столовой описываются уравнениями: QD = 2400 – 100P; QS = 1000 + 250P...

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

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