Модераторы: LSD, AntonSaburov

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Запись Object в MSSQL, как это сделать? 
:(
    Опции темы
Andyb
Дата 22.12.2005, 19:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 170
Регистрация: 7.6.2004
Где: Lille, France

Репутация: 4
Всего: 5



народ help нужно записать java Object в БД MSSQL
возможно ли такое? если да то плиз киньте примерчик smile
Добавлено @ 19:38
очень нада
--------------------
 Большинство наших ошибок происходит из-за невнимательности.
PM ICQ   Вверх
maximb
Дата 22.12.2005, 19:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Awaiting Authorisation
Сообщений: 48
Регистрация: 23.5.2005
Где: Украина, г.Симфер ополь

Репутация: 4
Всего: 6



Здесь возможно два варианта:

1. Сериализовать объект и сохранить в базу как BLOB (не очень хороший вариант, но иногда может быть полезен)

2. Мапить объект в базу. Можно напрямую через JDBC (но много руками придется поработать). Можно использоваеть фреймворк, например iBatis или Hibernate

Если поискать по форуму, то можно найти примеры как это делается. Также есть Google.


PM ICQ   Вверх
Andyb
Дата 22.12.2005, 19:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 170
Регистрация: 7.6.2004
Где: Lille, France

Репутация: 4
Всего: 5



а можно поподробнее про BLOB? smile
--------------------
 Большинство наших ошибок происходит из-за невнимательности.
PM ICQ   Вверх
maximb
Дата 22.12.2005, 19:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Awaiting Authorisation
Сообщений: 48
Регистрация: 23.5.2005
Где: Украина, г.Симфер ополь

Репутация: 4
Всего: 6



PM ICQ   Вверх
Andyb
Дата 22.12.2005, 20:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 170
Регистрация: 7.6.2004
Где: Lille, France

Репутация: 4
Всего: 5



так это понятно, мне непонятен процесс как мне допустим объект javax.mail.Message
записать в базу (очень буду рад фрагменту кода smile )(типа привести его к java.sql.Blob)

Это сообщение отредактировал(а) Andyb - 22.12.2005, 20:06
--------------------
 Большинство наших ошибок происходит из-за невнимательности.
PM ICQ   Вверх
LSD
Дата 22.12.2005, 20:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 210
Всего: 538



Вот пример сериализации. Тебе надо будет вместо файла использовать поток blob-а.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Andyb
Дата 22.12.2005, 20:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 170
Регистрация: 7.6.2004
Где: Lille, France

Репутация: 4
Всего: 5



объект :
Код

class mymessage extends javax.mail.Message implements java.io.Serializable{
........
}

здесь метод сохраняющий в базу:
Код

class mymessageSaver {
public void save(mymessage mess){
try{
                    String query = "INSERT INTO Messages(ID,message) "+
                    "VALUES(1,?)";
                    PreparedStatement st = dbModule.prepareStatement(query);
                    
                    st.setBlob(1, mess/*Так неправильно но вот что мне сюда ставить не пойму*/);
                    st.executeUpdate();
                    }
                    catch(SQLException ex){
                        ex.printStackTrace();
                    }
}

как мне сделать правильно? smile
--------------------
 Большинство наших ошибок происходит из-за невнимательности.
PM ICQ   Вверх
LSD
Дата 22.12.2005, 20:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 210
Всего: 538



Тут есть 2 варианта (какой будет работать у тебя не знаю, т.к. они обы привязанны к драйверу и СУБД)

1. Пишем в ByteArrayOutputStream
Код
ByteArrayOutputStream out = new ByteArrayOutputStream();
ObjectOutputStream objectOut = new ObjectOutputStream(out);    
objectOut.writeObject(client);    
objectOut.close();    
st.setBytes(1, out.toByteArray());

но тут можно нарваться на то что объекты больше n байт не пишутся (в Oracle при определенных условиях такое бывало).

2. Создаем blob, получем у него поток и пишем в него. Но как создавать blob зависит от СУБД. Для Oracle так:
Код
BLOB blob = BLOB.createTemporary(connection, true, BLOB.DURATION_SESSION);
ObjectOutputStream objectOut = new ObjectOutputStream(blob.setBinaryStream(0L));    
objectOut.writeObject(client);    
objectOut.close();    
st.setBlob(1, blob);

для MS SQL Server смотри его документацию.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Andyb
Дата 23.12.2005, 08:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 170
Регистрация: 7.6.2004
Где: Lille, France

Репутация: 4
Всего: 5



Большое спасибо LSD
smile "Обнаружена ошибка:
У Вас недостаточно постов, чтобы изменять репутацию пользователей. Необходимо 100 постов.
"
а жаль я бы добавил

Это сообщение отредактировал(а) Andyb - 23.12.2005, 08:33
--------------------
 Большинство наших ошибок происходит из-за невнимательности.
PM ICQ   Вверх
batigoal
Дата 23.12.2005, 09:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 24
Всего: 151



Цитата(Andyb @ 23.12.2005, 09:30)
"Обнаружена ошибка:
У Вас недостаточно постов, чтобы изменять репутацию пользователей. Необходимо 100 постов."
а жаль я бы добавил


Модераторы с удовольствием идут навстречу пожеланиям трудящихся, и делают это от вашего имени smile


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
LSD
Дата 23.12.2005, 10:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 210
Всего: 538



Цитата(Andyb @ 23.12.2005, 08:30)
Большое спасибо LSD

Да пожалуйта.

Да, забыл добавить второй вариант требует меньше памяти, но надо следить за освобождением ресурсов (временные blob надо обязательно потом "освобождать, иначе может замусориваться табличное пространство).


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Hidrag
Дата 2.7.2007, 16:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 877
Регистрация: 9.4.2005
Где: JDK

Репутация: 3
Всего: 25



а кто нибудь в курсе как блоб для MySQL оформить? Нужно записать в блоб обьект java.awt.Image, ну или сразу из файла, затем нужно прочитать из базы и нарисовать скажем в label


--------------------
user posted image
PM WWW ICQ   Вверх
powerOn
Дата 2.7.2007, 17:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



Цитата(Hidrag @  2.7.2007,  17:13 Найти цитируемый пост)
а кто нибудь в курсе как блоб для MySQL оформить? 

как понять "оформить"? MySQL BLOB поля поддерживает, нужно просто создать соответствующую колонку.

Цитата(Hidrag @  2.7.2007,  17:13 Найти цитируемый пост)
Нужно записать в блоб обьект java.awt.Image, ну или сразу из файла, затем нужно прочитать из базы и нарисовать скажем в label 

5-ю постами выше LSD привел способ записи объекта в БД. Все сводится к созданию необходимых потоков и отправки/получения данных в/из них. Картинки кстати удобно в поток писать с помошью ImageIO.  smile 


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
Hidrag
Дата 2.7.2007, 17:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 877
Регистрация: 9.4.2005
Где: JDK

Репутация: 3
Всего: 25



вот эту строку
Код

BLOB blob = BLOB.createTemporary(connection, true, BLOB.DURATION_SESSION);

 для мускула как записать? есть класс com.mysql.jdbc.blob но у него нет методов.

еще пытался так:

есть 
Код

pict = ImageIO.read(new File(path));
ByteArrayOutputStream out = new ByteArrayOutputStream();
ObjectOutputStream objectOut = new ObjectOutputStream(out);    
objectOut.writeObject(pict);    
objectOut.close();    
st.setBytes(1, out.toByteArray());

ругается так:
java.io.NotSerializableException: java.awt.image.BufferedImage
коннект к базе и статемент есстесно прописаны


--------------------
user posted image
PM WWW ICQ   Вверх
powerOn
Дата 2.7.2007, 19:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



Вот рабочий пример:

Код

import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.imageio.ImageIO;

public class Main
{

    public Main()
    {
    }

    public static void main(String[] args)
    {
        try
        {
            Class.forName("com.mysql.jdbc.Driver").newInstance();
            Connection connection =
                    DriverManager.getConnection("jdbc:mysql://localhost/testdb", "root", "12345");
            
            // Запись картинки в базу данных.
            BufferedImage pict = ImageIO.read(new File("C:/testimage.gif"));
            ByteArrayOutputStream out = new ByteArrayOutputStream();
            ImageIO.write(pict, "gif", out);
            
            String query1 = "INSERT INTO test(image) VALUES(?)";
            PreparedStatement st = connection.prepareStatement(query1);
            st.setBytes(1, out.toByteArray());
            
            System.out.println("Rows updated: " + st.executeUpdate());

            // Получение картинки из базы данных.
            String query2 = "SELECT * FROM test";
            Statement st2 = connection.createStatement();
            
            ResultSet rs = st2.executeQuery(query2);
            
            int i = 1;
            while (rs.next())
            {
                BufferedImage image = ImageIO.read(rs.getBlob("image").getBinaryStream());
                ImageIO.write(image, "gif", new File(i+".gif"));
                i++;
            }

            connection.close();
        }
        catch (Exception ex)
        {
            Logger.getLogger("global").log(Level.SEVERE, null, ex);
        }
    }
    
}


таблица test имеет 2 поля: test_id - Integer (счетчик) и image - BLOB.


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1103 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.