Форум программистов, компьютерный форум, киберфорум
Rust
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
21 / 21 / 5
Регистрация: 26.12.2013
Сообщений: 177

Работа с файлом mdb Microsoft Access через odbc драйвер. Вместо кириллических символов получаю знаки

25.04.2024, 00:53. Показов 757. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
Работа с файлом mdb Microsoft Access через odbc драйвер. Вместо кириллических символов получаю вопросительные знаки.

Rust
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
use odbc::*;
 
            let path = "D:/Access.mdb";
 
            let env = match create_environment_v3().map_err(|e| e.unwrap()) {
                Ok(res) => res,
                Err(e) => {
                    println!("{:?}", e);
                    return;
                }
            };
 
            let conn = match env.connect_with_connection_string(
                format!("Driver={};Dbq={};", "{Microsoft Access Driver (*.mdb, *.accdb)}", path).as_str()
            ) {
                Ok(res) => res,
                Err(e) => {
                    println!("{:?}", e);
                    return;
                }
            };
 
            let mut stmt = match Statement::with_parent(&conn) {
                Ok(res) => res,
                Err(e) => {
                    println!("{:?}", e);
                    return;
                }
            };
 
            let mut stmt = stmt.prepare("SELECT Name, ID, Code FROM Plan WHERE ID = ?").unwrap();
            let id = 2;
            let stmt = stmt.bind_parameter(1, &id).unwrap();
            let stmt = if let Data(mut stmt) = stmt.execute().unwrap() {
                if let Some(mut cursor) = stmt.fetch().unwrap() {
 
                    let name = cursor.get_data::<String>(1).unwrap().unwrap();
                    let p_id = cursor.get_data::<String>(2).unwrap().unwrap();
                    let code = cursor.get_data::<String>(3).unwrap().unwrap();
 
                    println!("{}", &name);
                    println!("{}", &p_id);
                    println!("{}", &code);
 
                }
                stmt.close_cursor().unwrap()
            } else {
                panic!("SELECT statement returned no result set");
            };

При получении name в ней содержаться ?????? ?.?. Причем в буфере cursor уже хранятся коды вопросов, поэтому изменение кодировки name не поможет. Английские символы выводятся корректно.

Подскажите пожалуйста, куда копать?

Добавлено через 1 час 8 минут
Получилось все исправить. Я несколько дней не мог найти решение. Хотя мог бы догадаться, ведь вопросы указывали на 16-битную кодировку.

В общем вот так исправил
Rust
1
2
3
4
5
6
            fn utf16_to_utf8(data: &[u16]) -> String {
                String::from_utf16_lossy(data)
            }
 
            let value = cursor.get_data::<Vec<u16>>(1).unwrap().unwrap();
            let name = utf16_to_utf8(&value);
1
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.04.2024, 00:53
Ответы с готовыми решениями:

Microsoft OLE DB Provider for ODBC Drivers (0x80004005) [Microsoft][Драйвер ODBC Microsoft Access]Общий сбой Не удается открыть раздел реестра...
Win2000AS Работает в качестве терминал сервера Перетащил тачку с этажа на этаж, Удалил NovellClient Перестали выполняться запросы к...

Странная ошибка с ODBC: [Microsoft][Драйвер ODBC Microsoft Access] Файл '(нет данных)' не может быть открыт ядром базы данных Microsoft Jet.
Внезапно вылезла вот такая ошибка: Файл '(нет данных)' не может быть открыт ядром базы данных Microsoft Jet. Файл уже открыт другим...

FireDAC Access (FireDAC Phys ODBC Microsoft Драйвер ODBC Microsoft Access Ошибка синтаксиса в предложении FROM.)
В SQL не силен, но приходится... В общем так: запрос наваял в Access, результат необходимый получил. А вот тот-же запрос через FireDAC...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.04.2024, 00:53
Помогаю со студенческими работами здесь

[Microsoft][ODBC Microsoft Access Driver] 'Hvorkinjavasample_analisys 'HVORKINJAVASAMPLE_ANALISYSDATABASESA'.mdb' is not a valid path
Здравствуйте! У меня JBuilder 4. Пишу апплет. База - MS SQL server. В апплете создан обьект database, соединенный через jdbc:odbc с...

Проблемы в ЧАТе: Microsoft OLE DB Provider for ODBC Drivers (0x80004005) [Microsoft][ODBC Microsoft Access Driver] Could not use '(unknown)' file
Попробовал поставить ЧАТ с переделанной бд из SQL в Access. При совместном доступе появл ошибка: Microsoft OLE DB Provider for ODBC...

Microsoft OLE DB Provider for ODBC Drivers error '80040e10' [Microsoft][ODBC Microsoft Access Driver] Too few parameters. Expected 3.
Hi All! имеется форма для добавления нового юзера в базу Set strConnString = Server.CreateObject('ADODB.Connection') ...

Microsoft OLE DB Provider for ODBC Drivers error '8007000e' [Microsoft][ODBC Microsoft Access Driver] Cannot open any more tables.
Microsoft OLE DB Provider for ODBC Drivers error '8007000e' Cannot open any more tables. a_func.inc, line 813 Кода этой ошибки...

проблемы с Access: [Microsoft][ODBC Microsoft Access Driver] The Microsoft Jet database engine cannot open the file '(unknown)'.
потребовалось на сервере с Access поработать (раньше все только с SQL Server было). Сам Access на сервере не стоит. При попытке подключения...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru