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

Вниз

Получить аттрибуты полей   Найти похожие ветки 

 
Arkaban ©   (2010-04-19 12:34) [0]

Всем добрый день.
Ситуация такая: в моем проекте на Delphi 7 есть TSQLDataSet, который выполняет запрос к базе данных. В результате получаем набор данных. Мне нужно этот набор данных разместить в другой базе данных. При этом, этот набор данных может иметь переменное число полей разных типов с разными аттрибутами. Как я могу получить эти аттрибуты? Аттрибуты scale, size, тип поля, NOT NULL я научился определять. А остальные (Charset, Collate,Default Source и т.д.) получить не могу. Пытаюсь получить их через FieldDefs, но не понимаю, как это сделать.
База данных на Yaffil.


 
Ega23 ©   (2010-04-19 12:38) [1]

TField.DataType + F1
А вообще я бы к системным таблицам обратился.


 
Arkaban ©   (2010-04-19 12:41) [2]

DataType дает только тип поля:  ftString, ftInteger и т.д.
Мне надо что-то вроде
TSQLDataSet.FieldDefs[i].Precision, TSQLDataSet.FieldDefs[i].Required и т.п.


 
Ega23 ©   (2010-04-19 12:43) [3]


> Мне надо что-то вроде
> TSQLDataSet.FieldDefs[i].Precision, TSQLDataSet.FieldDefs[i].
> Required и т.п.


К системным таблицам. Если поддерживается ANSI-шный стандарт по INFORMATION_SCHEMA - то туда.


 
Arkaban ©   (2010-04-19 12:46) [4]

То есть определять, к какой таблице относиться поле, обращаться к этой таблице у уже у нее смотреть аттрибуты поля?


 
Ega23 ©   (2010-04-19 12:56) [5]

Ты многого не получишь. Например, на поле наложен индекс (или ключ, или поле является частью составного ключа). Или ограничение. Или default-значение.
Набору данных это дело, по большому счёту, пофиг, он возвращает именно данные. Далее, простой пример:

create table ttt (aValue varchar(10) not null);
select cast(aValue as varchar(5)) as aValue from ttt;


Так вот, размер поля в наборе данных будет 5. А не 10.


 
Arkaban ©   (2010-04-19 13:19) [6]

Спасибо.



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

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

Наверх




Память: 0.45 MB
Время: 0.062 c
15-1272952103
Phoenix
2010-05-04 09:48
2010.08.27
Как подерживать себя в работоспособном состоянии.


15-1273069213
zedart
2010-05-05 18:20
2010.08.27
описание перменных


15-1275009183
wl
2010-05-28 05:13
2010.08.27
Путешествие из Петербурга в Москву (точнее наоборот)


2-1271881604
Б
2010-04-22 00:26
2010.08.27
Как вызвать процедуру по указателю на неё?


2-1270973363
@!!ex
2010-04-11 12:09
2010.08.27
Одновременная компиляции проекта в два exe.





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский