![]()  | 
	
 
  | 
		
			
  | 	
	
	
		
		|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны | 
![]()  | 
	
	
| 
		 | 
	Опции темы | Поиск в этой теме | Опции просмотра | 
| 
		 
			 
			#1  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Делаю выборку из БД (MS Access) по дате. 
		
	
		
		
		
		
		
	
		
		
	
	
	Никак не получается составить правильный запрос к БД. Пробовал так: Код: 
	ADOQuery1.Close; ADOQuery1.SQL.Clear; s:='select * from material '; s:=s+'where [Дата поступления] > #'+DateToStr(FromDate1.Date-1)+ '# and [Дата поступления]< #'+DateToStr(ToDate1.Date)+'#'; ADOQuery1.SQL.Add(s); ADOQuery1.Open; Вместо # использовал " - результат такой же. И так пробовал: Код: 
	 ADOQuery1.SQL.Text:=
'select * from material WHERE (data>= :date1) and (data<= :date2)';
ADOQuery1.Parameters.ParamByName('date1').Value:= FromDate1.DateTime;
ADOQuery1.Parameters.ParamByName('date2').Value:= ToDate1.DateTime;    | 
| 
		 
			 
			#2  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 1. Дата кодируется с помощью одиночных кавычек. 
		
	
		
		
		
		
		
	
		
		
	
	
	2. Лучше для параметров типа дата использовать параметризованный запрос. 3. Тип параметров задай принулительно (входной типа TDateTime)  | 
| 
		 
			 
			#3  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Спасибо, с параметрами всё работает отлично. 
		
	
		
		
		
		
		
		
			Кстати с одиночными кавычками тоже выдавало ошибку "Дата содержит синтаксическую ошибку в выражении запроса..." Последний раз редактировалось Eugene86, 26.09.2009 в 16:31.  | 
| 
		 
			 
			#4  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 попробуй так: 
		
	
		
		
		
		
			
		
		
		
		
	
		
		
	
	
	Код: 
	ADOQuery1.Close;
ADOQuery1.SQL.Text:='select * from materialcopy WHERE (data>= :date1) and (data<= :date2)';
ADOQuery1.ParamByName('date1').AsDateTime:= FromDate1.DateTime;
ADOQuery1.ParamByName('date2').AsDateTime:= ToDate1.DateTime;
ADOQuery1.Open; |