Модераторы: Partizan, gambit
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Выполнение запроса к базе PostgreSQL, Правильная кодировка 
V
    Опции темы
g0Od
Дата 4.8.2008, 14:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Здраствуйте!

Подскажите пожалуйста, есть такая проблема надо перегружать данные из БД Access в Postgres. Написал приложение на си шарпе, получает на вход запрос, коннектится с базами выполняет запрос, а потом полученные данные формирует в INSERT запросы и направляет в базу. Вот только одна беда кодировка базы utf8. Короче вылетает естетвенно ошибка про инвалидный инкодинг. Нашел функцию, которая переводит из одной кодировки в другую, но почему-то не помогает, пишет
:
Npgsql.NpgsqlException:
syntax error at or near "ДМИТРИЙ"

ну в таком духе. Можете подсказать в чем проблема? Ниже функция перекодировки:

static string Convert(string Value, System.Text.Encoding src, System.Text.Encoding dst)
        {
            System.Text.Decoder dec = src.GetDecoder();
            byte[] ba = dst.GetBytes(Value);
            int len = dec.GetCharCount(ba, 0, ba.Length);
            char[] ca = new char[len];
            dec.GetChars(ba, 0, ba.Length, ca, 0);
            return new string(ca);
        }

Кстати, по теме еще один вопрос. Вторым вариантом переноса данных является batch-перенос. Для этого сначала, по выполнению запроса формируется файл для экспорта (в нужной кодировке), который вставляется в запрос COPY в секцию FROM, т.е. вставляю путь к нему. На localhostе работает, а вот по сетке начинаются проблемы. К сожалению текст ошибок я здесь привести не могу, потому что они не очень то читаемы (я так понимаю на русском языке приходят, но все в том же UTF). Но насколько я понимаю проблемы возникает из-за того, что путь к файлу на локальной машине, как и сам файл, а вот запрос выполняется на сервере, а значит и путь ищется на сервере, а там ваще юникс.... Вобщем, как поступить? У меня есть одна идея - передавать файлик на сервер в расшаренную папку, но может есть более человеческое решение проблемы.
PM MAIL   Вверх
QryStaL
Дата 4.8.2008, 14:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Intellectual feast
**


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

Репутация: 14
Всего: 32



Строку подключения скинь


--------------------
I don't need a reason being who I am...
PM MAIL ICQ   Вверх
g0Od
Дата 4.8.2008, 15:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(QryStaL @ 4.8.2008,  14:23)
Строку подключения скинь

NpgsqlConnection conn = new NpgsqlConnection("Server="+serverName+";Port="+port+";User Id="+user+";Password="+pass+";Database="+database+";"); - для подключение к постгресу я использую библиотеку Npgsql.

Переменные являются опциональными параметрами приложения и задаются в командной строке, например:
serverName = 127.0.0.1 (либо, dns имя)
port = 5432 (стандартный)
ну а юзер и пароль правильные

Это сообщение отредактировал(а) g0Od - 4.8.2008, 15:03
PM MAIL   Вверх
QryStaL
Дата 4.8.2008, 15:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Intellectual feast
**


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

Репутация: 14
Всего: 32



Ну так само собой, кодировку-то не указал ))

Код

NpgsqlConnection conn = new NpgsqlConnection("Server=127.0.0.1;Port=5432;User Id=joe;Password=secret;Database=joedata;Encoding=UNICODE");



--------------------
I don't need a reason being who I am...
PM MAIL ICQ   Вверх
Rififi
Дата 4.8.2008, 15:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1254
Регистрация: 9.3.2008

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



вопрос не касаемо программной части: а обязательно сразу ломиться велосипед изобретать? Неужели никаких конвертеров не нашлось?
PM MAIL   Вверх
g0Od
  Дата 4.8.2008, 16:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(QryStaL @ 4.8.2008,  15:25)
Ну так само собой, кодировку-то не указал ))

Код

NpgsqlConnection conn = new NpgsqlConnection("Server=127.0.0.1;Port=5432;User Id=joe;Password=secret;Database=joedata;Encoding=UNICODE");

Спасибо огромное!  smile 

Кстати говоря, тогда и с кодировками извращаться не надо: просто исполняешь запросы как есть, а коннект сам их к должному виду приводит.  smile 

Если говорить про метод batch, использующий внешний файл и команду COPY, то сделал в программе две опции, одна из которых указывает путь в папку, куда сохранять данные для запроса (внешний файл), а вторая - путь, который использует сервер postgres для доступа к файлу с данными. Так что файл после создания отправляется в расшаренную папку, а потом только для запроса COPY в базу. Конечно, это легкий изврат, так сказать, но все таки при нескольких сотнях тысяч записях, когда команды инсерта срабатывают минут за 5, копи минут за 2 (сам копи срабатывает конечно быстрее, секунд 15, просто остальное время уходит на создание файла и расположение его в нужном месте).

Если у кого-нибудь есть рациональные предложения по вопросу, как можно использовать копи, не перегоняя файл в 30-50 Мб на сервер, пожалуйста говорите!
PM MAIL   Вверх
g0Od
Дата 4.8.2008, 16:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Конечно, кое-какие, программы есть, но они не очень-то удовлетворяют если честно.

Назови мне достойный "велосипед", и я с удовольствием на него "сяду".

Добавлено через 58 секунд
QryStaL - спасибо!!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
mr.DUDA
THandle

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.
Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :)
Так же не забывайте отмечать свой вопрос решенным, если он таковым является :)


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, THandle.

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


 




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


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

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