Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2008.07.13;
Скачать: [xml.tar.bz2];

Вниз

существование поля   Найти похожие ветки 

 
md10   (2008-02-03 00:50) [0]

как определить существование поля в таблице Table, (без использования SQL)


 
Германн ©   (2008-02-03 01:17) [1]

Копай в сторону DbiOpenFieldList.


 
Loginov Dmitry ©   (2008-02-03 11:35) [2]

if Table1.FieldByName("Имя_несуществующего_поля") = nil then
 ShowMessage("Поле не существует!");


 
md10   (2008-02-04 00:29) [3]


> Loginov Dmitry ©   (03.02.08 11:35) [2]
> if Table1.FieldByName("Имя_несуществующего_поля") = nil
> then
>  ShowMessage("Поле не существует!");

-)) так мы определили несуществующее поле, хочешь сказать следующее будет правильно по отношению к поиску существующего поля?
if Table1.FieldByName("Имя_существующего_поля") <> nil
then
 ShowMessage("Поле существует!");


 
Германн ©   (2008-02-04 00:49) [4]


> md10   (04.02.08 00:29) [3]
>
>


> -)) так мы определили несуществующее поле, хочешь сказать
> следующее будет правильно по отношению к поиску существующего
> поля?
> if Table1.FieldByName("Имя_существующего_поля") <> nil
> then
>  ShowMessage("Поле существует!");
>

Нет. Читай справку.
Call FieldByName to retrieve field information for a field given its name. FieldName is the name of an existing field. FieldByName returns the TField component that represents the specified field. If the specified field does not exist, FieldByName raises an EDatabaseError exception.


 
Loginov Dmitry ©   (2008-02-04 07:59) [5]

> If the specified field does not exist, FieldByName raises
> an EDatabaseError exception.


Видимо, за реализацию FieldByName() и за написание справки отвечали разные люди. Хотя в любой делфе для несуществующего поля метод просто возвращает nil


 
sniknik ©   (2008-02-04 08:24) [6]

> Хотя в любой делфе для несуществующего поля метод просто возвращает nil
в моей
function TDataSet.FieldByName(const FieldName: string): TField;
begin
 Result := FindField(FieldName);
 if Result = nil then DatabaseErrorFmt(SFieldNotFound, [FieldName], Self);
end;

полное соответствие со справкой.


 
Johnmen ©   (2008-02-04 09:05) [7]

В общем случае проверка [2] не является однозначной. Ибо поле м.б. в НД, но отсутствовать в реальной таблице.
И потом, этот способ "использует SQL", хотя этого и не видно явно.


 
Loginov Dmitry ©   (2008-02-04 09:10) [8]

Попутал. Сорри!

Теперь придется по работе исправлять результаты данного самовнушения =)


 
Loginov Dmitry ©   (2008-02-04 09:18) [9]

Вот досада! И править ничего не пришлось :(
Сам всю жизнь FindField() для проверки юзал, а тут такую ерунду насоветовал :(



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

Форум: "Базы";
Текущий архив: 2008.07.13;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.007 c
2-1213242326
Toropov
2008-06-12 07:45
2008.07.13
Как организовать помощь (Help) в своей программе?


15-1211878467
ekto
2008-05-27 12:54
2008.07.13
NASM


3-1201989045
md10
2008-02-03 00:50
2008.07.13
существование поля


15-1212020253
PEAKTOP
2008-05-29 04:17
2008.07.13
Delphi2007 и КПК.


3-1202138898
tomkat
2008-02-04 18:28
2008.07.13
критичный размер базы под FB





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский