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

Вниз

MySQL: VarChar -> Decimal   Найти похожие ветки 

 
BigError   (2004-09-10 21:15) [0]

Когда-то, начиная юзать MySQL, сделал глупость по неопытности - создал базу, где Currency хранил как VarChar. Теперь же, надо эти VarChar перевести в Decimal, но при смене типа столбца почему-то теряется из VarChar все, что было после запятой (включая саму запятую).
То есть, например, было VarChar(8)="1234,56", стало Decimal(8,2)=1234

Кто знает, почему так? И, самое главное, как теперь сменить тип столбца, ничего не потеряв?

В базе накопилось несколько тысяч записей, поэтому вариант "выпиши копейки на бумажку, смени тип и впиши ручками" нереален. Да и писать утиль, который сначала все сохранит, сменит тип столбцов, а потом перезапишет их, тоже особо времени нет. Но пока это все, что я придумал за 15 минут размышлений.
Но наверняка есть какой-то другой путь, бескровный.


 
sniknik ©   (2004-09-11 00:00) [1]

смени сначала запятую на точку перед переводом в в новый тип.
должно помочь.


 
Vasis   (2004-09-11 06:48) [2]

Можно экспортнуть таблицу в Excel, там сменить формат ячеек... и обратно импортнуть в таблицу... Благо на такую программу понадобится 2 минуты...


 
Smashich   (2004-09-11 09:22) [3]

добавить столбец. пройтись по всем записям конвертнув в нужный тип и записав в новый столбец. удалить старый



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

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

Наверх




Память: 0.47 MB
Время: 0.29 c
1-1095861749
DelphiLexx
2004-09-22 18:02
2004.10.10
Общедоступные паременные


1-1095779730
M-Alex
2004-09-21 19:15
2004.10.10
Timer


14-1095911456
Onix
2004-09-23 07:50
2004.10.10
Наука администрирования


14-1095187743
Fusly
2004-09-14 22:49
2004.10.10
SP2 for WinXP


14-1095630775
Knight
2004-09-20 01:52
2004.10.10
Бортовой "компьютер" БК-06...