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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.11.2007, 16:40
JIexa JIexa вне форума
Прохожий
 
Регистрация: 02.09.2007
Сообщения: 38
Репутация: 10
Печаль База данных "школа"

Вообщем решил сделать базу данных "Школа", но почему-то ничего не получилось! Когда нажимаешь поиск "Зарос" - поиск по фамилии, и вводишь, существующую фамилию выскакивает ошибка IMG - в низу!
Цитата:
DataSource1.DataSet:=Query1 // Когда выдается ошибка, показывает на эту строку!
Код:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, ExtCtrls, DBCtrls, DBTables, DB, Grids, DBGrids, StdCtrls, Menus;

type
  TForm1 = class(TForm)
    DBGrid1: TDBGrid;
    DataSource1: TDataSource;
    Table1: TTable;
    Query1: TQuery;
    DBNavigator1: TDBNavigator;
    Button1: TButton;
    Button2: TButton;
    MainMenu1: TMainMenu;
    N1: TMenuItem;
    N2: TMenuItem;
    N3: TMenuItem;
    N4: TMenuItem;
    N5: TMenuItem;
    N6: TMenuItem;
    N7: TMenuItem;
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    Procedure FormActivate(Sender:TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var fam: string[30];
begin
fam:=InputBox ('Ïîèñê ó÷åíèêà',
               'Óêàæèòå ôàìèëèþ è ùåëêíèòå "ÎÊ".', '');
if fam <> ''
then
begin
with form1.Query1 do begin
close;
SQL.Clear;

SQL.Add('SELECT Fam, Name, Otch, Class, Data, Adr');
SQL.Add('FROM ":Øêîëà:liceym.db"');
SQL.Add('WHERE');
SQL.Add('(Fam ="'+ Fam + '")');
SQL.Add('ORDER BY Fam, Name, Otch, Class, Data, Adr');
open;
end;
if Query1.RecordCount <> 0 then
DataSource1.DataSet:=Query1 // Когда выдается ошибка, показывает на эту строку!
 else begin
  ShowMessage ('Ïî âàøåìó çàïðîñó íè÷åãî íå íàéäåíî');
 Datasource1.DataSet:=Table1;
 end;
 end;
 end;

procedure TForm1.Button2Click(Sender: TObject);
begin
 DataSource1.DataSet:=Table1;
end;
Procedure TForm1.FormActivate(Sender:TObject);
begin
 DataSource1.DataSet:=Table1;
 Table1.Active:=True;
 end;
end.
Изображения
Тип файла: jpg Error.JPG (17.2 Кбайт, 19 просмотров)

Последний раз редактировалось JIexa, 14.11.2007 в 19:53.
Ответить с цитированием
  #2  
Старый 15.11.2007, 06:24
vlad19 vlad19 вне форума
Прохожий
 
Регистрация: 03.06.2007
Сообщения: 20
Репутация: 10
По умолчанию

Мешанина какаято используешь и TTable и TQuery. Пользуйся чем то одним, желательно TQuery. В запроспе используй Like, напиши справочники, например классы, фамилия имя отчество. Доберусь до своих исходников, пришлю пример.
Ответить с цитированием
  #3  
Старый 15.11.2007, 12:22
Аватар для Yurk@
Yurk@ Yurk@ вне форума
Специалист
 
Регистрация: 07.09.2007
Адрес: Украина, г. Днепропетровск
Сообщения: 892
Версия Delphi: 7 + ОгнеПтица
Репутация: выкл
По умолчанию

Я работал с этим примером (но не сохранил его к сожалению).
Он рабочий!
Пересмотри всё внимательно.
P.S. SELECT ..... пиши всё в одну строчку (так удобней).
__________________
Поживу - увижу, Доживу - узнаю, Выживу - учту.
[P.S.]->Выражая благодарность за помощь - Вы получаете шанс на помощь в следующий раз
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter