В Rails 3 MSSQL 2005 проблема с полем типа данных xml усечена до 2070 байт
Я под:
Windows XP
MSSQL 2005
Rails 3.0.9
ActiveRecord-SQLServer-адаптер
tinytds
Когда я пытаюсь получить содержимое поля с типом xml, я сталкиваюсь с проблемой, что строка xml обрезается.
Заранее благодарю за помощь
Это xml, который хранится в БД (извините за русские буквы):
<application>
<patent-type>Заявка на винахід</patent-type>
<title>WAY</title>
<native-number>inner123</native-number>
<inid51 type="array" />
<inid54>
<x54-title-ukr>WAY</x54-title-ukr>
<x54-title-rus />
<x54-title-eng />
</inid54>
<applicants type="array">
<applicant order="1">
<app-person>physical</app-person>
<app-name-ukr>Drobyazko Ob Ob</app-name-ukr>
<app-addr-ukr>Ukrainka</app-addr-ukr>
<app-country>UA</app-country>
<app-kzo />
<app-name-rus />
<app-addr-rus />
<app-name-eng />
<app-addr-eng />
</applicant>
<applicant order="2">
<app-person>physical</app-person>
<app-name-ukr>Stetsenko Ser Vol</app-name-ukr>
<app-addr-ukr>Kyiv</app-addr-ukr>
<app-country>UA</app-country>
<app-kzo />
<app-name-rus />
<app-addr-rus />
<app-name-eng />
<app-addr-eng />
</applicant>
</applicants>
<inventors type="array">
<inventor order="1">
<inv-name-ukr>Drobyazko Ob Ob</inv-name-ukr>
<inv-addr-ukr>Ukrainka</inv-addr-ukr>
<inv-country>UA</inv-country>
<inv-publ>Ні</inv-publ>
<inv-name-rus />
<inv-addr-rus />
<inv-name-eng />
<inv-addr-eng />
</inventor>
<inventor order="2">
<inv-name-ukr>Stetsenko Ser Vol</inv-name-ukr>
<inv-addr-ukr>Kyiv</inv-addr-ukr>
<inv-country>UA</inv-country>
<inv-publ>Ні</inv-publ>
<inv-name-rus />
<inv-addr-rus />
<inv-name-eng />
<inv-addr-eng />
</inventor>
</inventors>
<priorities>
<priority-cfg>
<type>prr-none</type>
<prr-date />
<prr-numb />
<is-priority-3x />
<is-priority-62 />
<is-priority-66 />
</priority-cfg>
<priority-3x type="array" />
<priority-62 type="array" />
<priority-66 type="array" />
</priorities>
<inid86>
<x86-numb />
<x86-date />
</inid86>
<inid87>
<x87-numb />
<x87-date />
</inid87>
<representative>
<repr-name>Drobyazko Ooo KKK</repr-name>
<repr-regnum>200</repr-regnum>
<repr-person>legal</repr-person>
</representative>
<address>
<addr-country>UA</addr-country>
<addr-zipcode />
<addr-region />
<addr-town-type>м.</addr-town-type>
<addr-town-val>Kyiv</addr-town-val>
<addr-rayon />
<addr-street-type>вул.</addr-street-type>
<addr-street-val />
<addr-building-type>буд.</addr-building-type>
<addr-building-val />
<addr-room-type>кв.</addr-room-type>
<addr-room-val />
<addr-addressee-person>physical</addr-addressee-person>
<addr-addressee>Drobyazko Dkkd Lll</addr-addressee>
<addr-tel>2323232</addr-tel>
<addr-fax />
<addr-email />
<full-address>м. Kyiv, UA; Drobyazko Dkkd Lll</full-address>
</address>
<flags>
<force-publication />
<patent-foreign />
</flags>
</application>
Используя Eclaim.find(1).app_xml, я получаю содержимое поля, упомянутого выше.
Также я записываю поле xml в файл File.open ("c: /w.txt", 'wb') {| f | f.write Eclaim.find (100003).app_xml}
Содержимое файла (размер 2070 байт):
<application><patent-type>Заявка на винахід</patent-type><title>WAY</title><native-number>inner123</native-number><inid51 type="array"/><inid54><x54-title-ukr>WAY2</x54-title-ukr><x54-title-rus/><x54-title-eng/></inid54><applicants type="array"><applicant order="1"><app-person>physical</app-person><app-name-ukr>Drobyazko Ob Ob</app-name-ukr><app-addr-ukr>Ukrainka</app-addr-ukr><app-country>UA</app-country><app-kzo/><app-name-rus/><app-addr-rus/><app-name-eng/><app-addr-eng/></applicant><applicant order="2"><app-person>physical</app-person><app-name-ukr>Stetsenko Ser Vol</app-name-ukr><app-addr-ukr>Kyiv</app-addr-ukr><app-country>UA</app-country><app-kzo/><app-name-rus/><app-addr-rus/><app-name-eng/><app-addr-eng/></applicant></applicants><inventors type="array"><inventor order="1"><inv-name-ukr>Drobyazko Ob Ob</inv-name-ukr><inv-addr-ukr>Ukrainka</inv-addr-ukr><inv-country>UA</inv-country><inv-publ>Ні</inv-publ><inv-name-rus/><inv-addr-rus/><inv-name-eng/><inv-addr-eng/></inventor><inventor order="2"><inv-name-ukr>Stetsenko Ser Vol</inv-name-ukr><inv-addr-ukr>Kyiv</inv-addr-ukr><inv-country>UA</inv-country><inv-publ>Ні</inv-publ><inv-name-rus/><inv-addr-rus/><inv-name-eng/><inv-addr-eng/></inventor></inventors><priorities><priority-cfg><type>prr-none</type><prr-date/><prr-numb/><is-priority-3x/><is-priority-62/><is-priority-66/></priority-cfg><priority-3x type="array"/><priority-62 type="array"/><priority-66 type="array"/></priorities><inid86><x86-numb/><x86-date/></inid86><inid87><x87-numb/><x87-date/></inid87><representative><repr-name>Drobyazko Ooo KKK</repr-name><repr-regnum>200</repr-regnum><repr-person>legal</repr-person></representative><address><addr-country>UA</addr-country><addr-zipcode/><addr-region/><addr-town-type>м.</addr-town-type><addr-town-val>Kyiv</addr-town-val><addr-rayon/><addr-street-type>вул.</addr-street-type><addr-street-val/><addr-building-type>буд.</addr-building-type><addr-building-val/><addr-room-type>кв.</addr-room-type><addr-room-val/><addr-addressee-person>physical</addr-addressee-
Похоже, что Rails усекает содержимое поля xml до 2070 байт.
Кто-нибудь может мне помочь?
1 ответ
Я часто вижу этот вопрос, и на него есть очень простой ответ. В SQL Server есть параметр TEXTSIZE (1), который имеет относительно небольшой размер для соединений DBLIB/TinyTDS. Недавно здесь я установил для адаптера размер, который будет имитировать ODBC-соединение по умолчанию (2). У нас также есть раздел в README (3) для более старых версий адаптера, который позволяет вам настроить соединение, чтобы вы могли, среди прочего, также установить TEXTSIZE.