![]()  | 
	
 
  | 
		
			
  | 	
	
	
		
		|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны | 
![]()  | 
	
	
| 
		 | 
	Опции темы | Поиск в этой теме | Опции просмотра | 
| 
		 
			 
			#1  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Есть база данных на sql с номерами телефонов и пример поиска из edit нужного телефона в ней 
		
	
		
		
		
		
		
		
			Код: 
	ADOQueryPoisk.Sql.Add(select NomerTel.id from NomerTel where Номер like :PoiskNomer);
ADOQueryPoisk.Parameters.ParamByName('PoiskNomer').Value := StrToFloat(Edit1.Text);Номер телефона ищется только при полном совпадении, а как сделать, чтобы искалась только какая-то часть номера? Последний раз редактировалось lmikle, 27.08.2015 в 17:54.  | 
| 
		 
			 
			#2  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 LIKE %text% спасет отца русской демократии: 
		
	
		
		
		
		
		
	
		
		
	
	
	Код: 
	ADOQueryPoisk.Sql.Add(select NomerTel.id from NomerTel where Номер like :PoiskNomer);
ADOQueryPoisk.Parameters.ParamByName('PoiskNomer').Value := '%' + StrToFloat(Edit1.Text) + '%'; | 
| 
		 
			 
			#3  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Уже пробовал. Выдает ошибку несоответствие типов, так как у переменной PoiskNomer тип float (числовой, а не строковый), как и у столбца Номер. Проблема в том, чтобы сделать проверку вхождения одного числа в другое. Возможно ли это для чисел в Delphi 2010? 
		
	
		
		
		
		
		
	
		
		
	
	
	 | 
| 
		 
			 
			#4  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Ну, можно и конвертнуть в строку (прямо в запросе). База Аксес? 
		
	
		
		
		
		
		
	
		
		
	
	
	Вообще, нафига тел. № сохранять как число??? Да еще и типа float. Переделай в строку, будет проще. Еще варианты: 1. Можно попробовать сгенерировать такой набор чисел и условий из введенного числа, которые будут работать аналогично LIKE. Проблемма, что кол-во условий (комплексеых, которые будут записаны через OR) будет Length(Phone)-Length(PhonePart)+1, замучаешься отлаживать. 2. Можно просто выборку проверять на клиенте, получить весь датасет и его уже динамически фильтровать. Т.к. тут фильтрация идет кодом, то можно писать любые проверки, в т.ч. и через конвертацию в строку и простой Pos.  |