Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 28.06.2011, 21:21
Аватар для Klassenas
Klassenas Klassenas вне форума
Новичок
 
Регистрация: 25.05.2009
Адрес: Казахстан, Павлодар
Сообщения: 87
Версия Delphi: Rad Studio 2010
Репутация: 1570
Вопрос Изменение структуры БД Access

Как програмно изменить структуру БД Access? Нужно изменить размер текстового поля. Использую ADOCommand. Пишу: 'ALTER TABLE TableName MODIFY (FieldName TEXT(100))' Ругается на неверный синтаксис. Если вместо MODIFY использую ADD то всё нормально. В чём ошибка? Может, есть другие способы?
__________________
Если ты чего-то не знаешь, значит есть шанс научиться чему-то новому
Ответить с цитированием
  #2  
Старый 29.06.2011, 08:27
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

А что это за оператор такой MODIFY?
Имхо, стоит тебе покурить мануалы по SQL.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 29.06.2011, 10:54
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

В принципе автор верно все делает, вот только это SQL-диалект для Оракла. А классический SQL не предусматривает такой инструкции. Вообще наверное каждый SQL-сервер имеет что-то специфичное только для него.
В вашем случает будет скорее всего так:
Код:
ALTER TABLE TableName ALTER COLUMN FieldName TEXT(100)
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #4  
Старый 01.07.2011, 22:13
Аватар для Klassenas
Klassenas Klassenas вне форума
Новичок
 
Регистрация: 25.05.2009
Адрес: Казахстан, Павлодар
Сообщения: 87
Версия Delphi: Rad Studio 2010
Репутация: 1570
По умолчанию

Спасибо, с редактированием разобрался.
Теперь у меня другое шило:
Каким образом при помощи SQL-запроса узнать тип и аттрибуты столбца?
Например, есть параметр :TN в который должна возвращаться строка с типом столбца, чтобы потом эту строку можно было использовать в инструкции ALTER TABLE.
__________________
Если ты чего-то не знаешь, значит есть шанс научиться чему-то новому
Ответить с цитированием
  #5  
Старый 02.07.2011, 08:04
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

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

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #6  
Старый 03.07.2011, 22:04
Аватар для Klassenas
Klassenas Klassenas вне форума
Новичок
 
Регистрация: 25.05.2009
Адрес: Казахстан, Павлодар
Сообщения: 87
Версия Delphi: Rad Studio 2010
Репутация: 1570
По умолчанию

Цитата:
Сообщение от Aristarh Dark
Есть системные таблицы, в них описаны пользовательские таблицы и поля. В настройках акцеса поставь галку "отображать системные таблицы" или как-то так, и смотри в них.
А по-подробнее можно?
У меня ADOConnection возвращает следующий список системных каталогов базы данных: MSysACEs, MSysObjects, MSysQueries, MSysRelationships. Где конкретно искать нужную информацию?
__________________
Если ты чего-то не знаешь, значит есть шанс научиться чему-то новому
Ответить с цитированием
  #7  
Старый 05.07.2011, 13:32
Аватар для Viajero
Viajero Viajero вне форума
Активный
 
Регистрация: 14.06.2011
Адрес: РБ
Сообщения: 214
Версия Delphi: Delphi 7 FB 2.5
Репутация: 5849
По умолчанию

У объекта TField есть свойства DataType, DataSize и т п , можно ещё покопать свойства и методы ADODB объектов, а системными таблицами я бы не стал пользоваться
Ответить с цитированием
  #8  
Старый 05.07.2011, 13:51
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Цитата:
Сообщение от Viajero
У объекта TField есть свойства DataType, DataSize и т п , можно ещё покопать свойства и методы ADODB объектов, а системными таблицами я бы не стал пользоваться
Можете объяснить почему?
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #9  
Старый 05.07.2011, 13:52
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Цитата:
Сообщение от Klassenas
А по-подробнее можно?
У меня ADOConnection возвращает следующий список системных каталогов базы данных: MSysACEs, MSysObjects, MSysQueries, MSysRelationships. Где конкретно искать нужную информацию?

Я не помню уже, 100 лет назад это было. Посмотри что в этих таблицах, там все понятно + почитай MSDN.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 18:22.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter