Squeak.ru - шаблоны программирования

Строка XML в xml не может переключить кодировку

У меня есть строка XML, которая имеет неправильный формат.

DECLARE @xmlt TABLE(xstr nvarchar(max), xml xml)

INSERT INTO @xmlt(xstr) VALUES (
'  <?xml version="1.0" encoding="windows-1257" ?>
- <objects><object id="778913">a</object>
- <object id="785491">b</object>
- <object ...goes on...
- </objects>
'

Чтобы иметь возможность использовать этот XML, я конвертирую его в XML.

UPDATE @xmlt SET xml = CAST(REPLACE(LTRIM(xstr), ' - <', '<') AS xml);

Но получаю ошибку XML parsing: line 1, character 46, unable to switch the encoding.

Есть ли другой способ (без замены строки encoding="windows-1257" на "") преобразовать эту строку XML в xml в SQL Server?


  • Примечание: Xml в вашем образце не имеет корневого узла над всеми узлами ‹object›, это недопустимо. 21.05.2015
  • Хороший комментарий, :) спасибо! В xml он действительно есть. Обновил пример. 21.05.2015

Ответы:


1

Поле xstr nvarchar(max) несовместимо с кодировкой windows-1257. Если вы используете varchar(max), он не прекратит преобразование строки в XML. Тип Varchar и кодировка Xml связаны. Если ваша XML-кодировка имеет юникод (например, UFT-16), то использование nvarchar сработало бы.

Это будет работать с вашей строкой xml:

DECLARE @xmlt TABLE(xstr varchar(max), xml xml)

insert into @xmlt(xstr) values( '<?xml version="1.0" encoding="windows-1257"?>
- <objects>
- <object id="778913">a</object>
- <object id="785491">b</object>
- </objects>')

update @xmlt set xml = cast ( REPLACE(ltrim(xstr),' - <','<') as xml)
21.05.2015
  • Не могли бы вы помочь мне с этим: stackoverflow.com/questions/32230486/ 26.08.2015
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...