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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 20.11.2010, 16:53
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию Диапазон поиска в БД

БД На аксесе, мне нужно знать например какие нарушения совершили сотрудники от 12.12.04 по 13.04.05, неполучается это сдела и вывести например в мемо помогите вот код по которому я работаю могу дать исходник парни выручайте

Код:
procedure TForm1.Button1Click(Sender: TObject);
var
f:string;
b:string;
i:integer;
begin
f:=Edit1.Text;
b:=Edit2.Text;
i:=Datamodule2.ADOTable1.RecordCount;
DataModule2.ADOTable1.First;
while i>0 do
begin
i:=i-1;
if
(DataModule2.ADOTable1DSDesigner??.AsString>f)
and (DataModule2.ADOTable1DSDesigner??.AsString<b)
then

??
DataModule2.ADOTable1.Next;
end;

end;
Ответить с цитированием
  #2  
Старый 20.11.2010, 19:33
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,087
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А не проще сделать через запрос?
сам запрос:
Код:
SELECT * FROM [Table] WHERE [DateField] > :DF AND [DateField] < :DE
Заменить имя таблицы и поле даты, что в кв. скобках, на твои.

код
Код:
var
  I : Integer;
  S : String;
begin
ADOQuery1.Params.PAramByName('DF').AsTDateTime := DateTimePicker1.Date;
ADOQuery1.Params.PAramByName('DE').AsTDateTime := DateTimePicker1.Date;
ADOQuery1.Open;
ADOQuery1.First;
While Not ADOQuery1.EOF Do
Begin
  S := '';
  For I := 0 To ADOQuery1.Fields.Count-1 Do
    S := S + ADOQuery1.Fields[0].AsString + ' ';
  Memo1.Lines.Add(S);
  ADOQuery1.Next;
End;
Ответить с цитированием
  #3  
Старый 20.11.2010, 20:00
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Извените сразу не сказал я не использую ADoQuery и неочень знаком с SQL вы можете помочь может ее будет просто переделать под ADoQuery чем решить мою проблему?
Ответить с цитированием
  #4  
Старый 21.11.2010, 12:37
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

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


_http://zalil.ru/30003517

ну или так обьясните я сам попробую..
Ответить с цитированием
  #5  
Старый 21.11.2010, 14:47
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Использовать ручной обход всех записей для решения вашей проблемы - изначально неверная постановка задачи. lmikle вам предложил хорошую альтернативу, но хозяин барин:
Код:
var
f,b:TDateTime;
begin
f := StrToDateTime(Edit1.Text);
b := StrToDateTime(Edit2.Text);
while not AdoTable1.Eof
do begin
    if (AdoTable1.FieldByName('ДатаНарушения').asDateTime >= b) and 
       (AdoTable1.FieldByName('ДатаНарушения').asDateTime <= f)
    then Memo1.Lines.Add(AdoTable1.FieldByName('ФИО').asString);
    AdoTable1.Next;
    end; 
end;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #6  
Старый 21.11.2010, 16:41
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Спасибо, я понимаю что это может быть легче.. но врядли для меня,
в вашем коде у меня ошибки на:

while not AdoTable1.Eof

и здесь..

if (AdoTable1.FieldByName(

блиин..(((((
Ответить с цитированием
  #7  
Старый 22.11.2010, 09:21
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Цитата:
Сообщение от Страдалецъ
Использовать ручной обход всех записей для решения вашей проблемы - изначально неверная постановка задачи. lmikle вам предложил хорошую альтернативу, но хозяин барин:
Код:
var
f,b:TDateTime;
begin
f := StrToDateTime(Edit1.Text);
b := StrToDateTime(Edit2.Text);
while not AdoTable1.Eof
do begin
    if (AdoTable1.FieldByName('ДатаНарушения').asDateTime >= b) and 
       (AdoTable1.FieldByName('ДатаНарушения').asDateTime <= f)
    then Memo1.Lines.Add(AdoTable1.FieldByName('ФИО').asString);
    AdoTable1.Next;
    end; 
end;

с этим разобрался но результата не дало((
Ответить с цитированием
  #8  
Старый 22.11.2010, 13:11
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

У вас дата в таблице каким образом хранится? Как текст или дата?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #9  
Старый 22.11.2010, 13:54
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

как "Дата/время"
Ответить с цитированием
  #10  
Старый 22.11.2010, 22:21
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Помогите.. я уже незнаю че делать, уже облазил все что можно
Ответить с цитированием
  #11  
Старый 23.11.2010, 08:51
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

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


Код:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, Grids, DBGrids, ExtCtrls, DBCtrls, StdCtrls, ToolWin, ComCtrls;

type
  TForm1 = class(TForm)
    DBGrid1: TDBGrid;
    DBNavigator1: TDBNavigator;
    ToolBar1: TToolBar;
    Edit1: TEdit;
    CheckBox1: TCheckBox;
    CheckBox2: TCheckBox;
    CheckBox3: TCheckBox;
    Button1: TButton;
    Edit2: TEdit;
    Memo1: TMemo;
    procedure Button1Click(Sender: TObject);
    procedure CheckBox1Click(Sender: TObject);
    procedure CheckBox2Click(Sender: TObject);
    procedure CheckBox3Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

uses Unit2, Unit3;

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var
f,b:TDateTime;
begin

f := StrToDateTime(Edit1.Text);
b := StrToDateTime(Edit2.Text);
while not Datamodule2.AdoTable1.Eof
do begin
    if (DataModule2.ADOTable1.FieldByName('Дата_нарушения').asDateTime >= b) and
       (DataModule2.AdoTable1.FieldByName('Дата_нарушения').asDateTime <= f)

    then Memo1.Lines.Add(Datamodule2.AdoTable1.FieldByName('Дата_нарушения').asString);
    DataModule2.AdoTable1.Next;
    end; 
end;



procedure TForm1.CheckBox1Click(Sender: TObject);
var
a:string;
begin
a:=CheckBox1.Caption;
if CheckBox1.Checked then
DataModule2.ADOTable1.Filtered:=false;
DataModule2.ADOTable1.Filter:='Нарушение='''+a+'''';
DataModule2.ADOTable1.Filtered:=true;
end;

procedure TForm1.CheckBox2Click(Sender: TObject);
var
a:string;
begin
a:=CheckBox2.Caption;
if CheckBox2.Checked then
DataModule2.ADOTable1.Filtered:=false;
DataModule2.ADOTable1.Filter:='Нарушение='''+a+'''';
DataModule2.ADOTable1.Filtered:=true;
end;

procedure TForm1.CheckBox3Click(Sender: TObject);
var
a:string;
begin
a:=CheckBox3.Caption;
if CheckBox3.Checked then
DataModule2.ADOTable1.Filtered:=false;
DataModule2.ADOTable1.Filter:='Нарушение='''+a+'''';
DataModule2.ADOTable1.Filtered:=true;
end;

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

А почему вы считаете что неработает? Вы какие значения вводите в переменные b и f и какое значение по вашему не попадает в это диапазон?
Вы пробовали пошагово выполнить и посмотреть, что и чему равно в момент сравнения?
Возможно проблема как-то связано с временем которое не отображается в дате. Возможно еще, что системный формат даты несколько отличается от формата хранения в БД.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.

Последний раз редактировалось Страдалецъ, 23.11.2010 в 17:56.
Ответить с цитированием
  #13  
Старый 23.11.2010, 18:04
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Дело может в том что проблема с выводом в мемо может? попробывать не в мемо а в другое что нибудь.. но я не знаю как лучше, 12.12.1990 это формат даты, он используется и в аксесе и в делфи.. вы немогля бы глянуть, хотябы попробывать сделать чтобы работало продемонстрировать(для честности не довать исходник) а я попробую сделать сам.. просто щас так выходит что это становится дя меня не реальным(

Последний раз редактировалось true, 23.11.2010 в 18:13.
Ответить с цитированием
  #14  
Старый 25.11.2010, 07:52
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

И снова молчок..
Ответить с цитированием
  #15  
Старый 25.11.2010, 11:10
Аватар для movnet
movnet movnet вне форума
Начинающий
 
Регистрация: 24.07.2008
Сообщения: 127
Версия Delphi: Delphi 7
Репутация: 23
По умолчанию

Код:
procedure TForm1.Button1Click(Sender: TObject);
var
f,b:TDateTime;
begin

b := StrToDateTime(Edit1.Text);
f := StrToDateTime(Edit2.Text);
Datamodule2.AdoTable1.First;
while not Datamodule2.AdoTable1.Eof do begin
    if (DataModule2.ADOTable1.FieldByName('Дата_нарушения').asDateTime >= b) and
       (DataModule2.AdoTable1.FieldByName('Дата_нарушения').asDateTime <= f)

    then Memo1.Lines.Add(DateTimeToStr(Datamodule2.AdoTable1.FieldByName(
      'Дата_нарушения').Value));
    Datamodule2.AdoTable1.Next;
    end;
end;
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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