Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.07.04;
Скачать: CL | DM;

Вниз

Как переконвертировать Long v VarChar2 ?   Найти похожие ветки 

 
DPashin   (2002-06-10 09:08) [0]

Имеется таблица с полем типа Long, содержащим строки длиной от 0 до 500 символов. Нужно преобразовать это поле к типу данных Varchar2. Как это сделать средствами Oracle, желательно через SQL?
Версия сервера-8.1.6.


 
DarkGreen   (2002-06-10 11:40) [1]

//Создаем временое поле

alter table my_tbl
add (new_field carchar2(500));

//Заносим в него данные из старого поля

update my_tbl
set new_field = old_field;

//Удаляем старое поле

alter table
drop column old_field;

//Пересоздаем его с нужным типом данных

alter table my_tbl
add (old_field carchar2(500));

//Опять данные перекачиваем

update my_tbl
set old_field = new_field;

//Удаляем временное поле

alter table
drop column new_field;

Или вот так, покороче, хотя может не получится (не знаю сможет ли от LONG в VARCHAR2 преобразовать:

alter table
modify (old_field varchar2(500));


 
DPashin   (2002-06-10 15:07) [2]

Может я конечно не прав, но

>//Заносим в него данные из старого поля
>update my_tbl
> set new_field = old_field;

не работает (Invalid use of long dataType).




 
MishGan`   (2002-06-10 15:50) [3]

Это можно сделать с использованием OCI (или чего нибудь подобного) только на клиенте.
Средства SQL/PLSQL не позволяют напрямую работать с LONG/LONG RAW полями.


 
DPashin   (2002-06-11 06:06) [4]

Спасибо.



Страницы: 1 вся ветка

Текущий архив: 2002.07.04;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.014 c
14-9972
Snake bite
2002-06-02 19:49
2002.07.04
Господа а в чем смысл жизни?


6-9950
konrads
2002-04-22 07:53
2002.07.04
Сетевой трафик


6-9945
ec
2002-04-22 12:51
2002.07.04
ICQ+SMS


1-9865
BlackSun
2002-06-21 18:01
2002.07.04
Как прибить процесс по имени запускаемого файла.


14-9989
hooch
2002-06-04 06:33
2002.07.04
Таймер