![]()  | 
	
 
  | 
		
			
  | 	
	
	
		
		|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны | 
![]()  | 
	
	
| 
		 | 
	Опции темы | Поиск в этой теме | Опции просмотра | 
| 
		 
			 
			#1  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Здравствуйте. Помогите пожалуйста очень прощу. 
		
	
		
		
			При добавлений записи в таблицу вместо казахских букв отображается вопросительный знак. Таблица в Mysql. Подключаюсь к базе через fdconnection. Запись добавляю через fdquery. Вот такой код использую для добавление записи: Код: 
	if Assigned(GlavFrm) then
    begin
      GlavFrm.FDQuery1.SQL.Text := 'INSERT INTO Malimet (tabel, name, birthday, citizenship, nationality, gender, military_rank, photo, password) VALUES (:tabel, :name, :birthday, :citizenship, :nationality, :gender, :military_rank, :photo, :password)';
      GlavFrm.FDQuery1.ParamByName('tabel').AsString := Edit1.Text;
      GlavFrm.FDQuery1.ParamByName('name').AsString := UTF8Encode(Edit2.Text);
      GlavFrm.FDQuery1.ParamByName('birthday').Value := DateTimePicker1.Date;
      GlavFrm.FDQuery1.ParamByName('citizenship').AsString := ComboBox1.Text;
      GlavFrm.FDQuery1.ParamByName('nationality').AsString := ComboBox2.Text;
      GlavFrm.FDQuery1.ParamByName('gender').AsString := ComboBox3.Text;
      GlavFrm.FDQuery1.ParamByName('military_rank').AsString := ComboBox4.Text;
      GlavFrm.FDQuery1.ParamByName('photo').AsString := label8.Caption;
      GlavFrm.FDQuery1.ParamByName('password').AsString := Edit3.Text;
      GlavFrm.FDQuery1.ExecSQL;
    end;Код: 
	GlavFrm.FDQuery1.SQL.Clear;
  // Выполняем запрос для выборки данных
        GlavFrm.FDConnection1.Connected := True; // Подключаемся к базе данных
        GlavFrm.FDConnection1.Params.Values['CharacterSet'] := 'utf8';
        GlavFrm.FDQuery1.SQL.Text := 'SELECT * FROM malimet';
        GlavFrm.FDQuery1.Open; | 
| 
		 
			 
			#2  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 А если каким-нить сторонним тулом глянуть в БД? Там правильно отображается или тоже кракозябры? Очень уж похоже, что проблема на стороне базы данных, там надо задать дефолтную кодировку для полей при создании полей. 
		
	
		
		
		
		
		
	
		
		
	
	
	 | 
| Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
 
Aibekkoke (09.02.2024)
  | ||
| 
		 
			 
			#3  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Цитата: 
	
  | 
| 
		 
			 
			#4  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 А если конвертнуть в AnsiString с нужной кодировкой? Убери установку utf-8 и при встаке конвертируй строки в нужную кодировку. Может поможет... 
		
	
		
		
		
		
		
	
		
		
	
	
	 | 
| Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
 
Aibekkoke (09.02.2024)
  | ||
| 
		 
			 
			#5  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Цитата: 
	
  | 
| 
		 
			 
			#6  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Кстати, а какая кодовая страница стоит по умолчанию? 
		
	
		
		
		
		
		
	
		
		
	
	
	Посмотри значение в System.DefaultSystemCodePage Если неправильная, то вызови метод System.SetMultiByteConversionCodePage для установки правильной кодировки.  | 
| Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
 
Aibekkoke (09.02.2024)
  | ||
| 
		 
			 
			#7  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Цитата: 
	
 ShowMessage('Текущая кодовая страница: ' + IntToStr(System.DefaultSystemCodePage)); показывает 1251 System.SetMultiByteConversionCodePage(65001); Потом пробовал установить utf-8, тогда вместо букв какие кракозябры появилось. И еще если записать данные из dbgrid тогда все буквы нормально отображается. А если добавить из edit-ов и combobox-ов тогда вместо казахских букв вопросительный знак. Не знаю что делать теперь:-(  | 
| 
		 
			 
			#8  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Ну, 1251 - это русская кодировка. 
		
	
		
		
		
		
		
	
		
		
	
	
	Я не знаю, для казахских букв существует отдельная кодировка или они должны быть частью русской. Еще 2 момента. Я бы проверил кодировку для не-юникодных программ в Windows (это настройка). Потом посмотри (попробуй) в TEdit в св-ве Font поставить нужный чрасет, может там собака порылась...  | 
| Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
 
Aibekkoke (09.02.2024)
  | ||
| 
		 
			 
			#9  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Цитата: 
	
 А если использовать базу данных acsess тогда все отлично добавляется. Не знаю уже что делать. Сколько дней сижу     ![]()  | 
| 
		 
			 
			#10  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Теперь работает: 
		
	
		
		
		
		
		
	
		
		
	
	
	Form3.FDQuery1.ParamByName('tabel').DataType := ftWideString; Form3.FDQuery1.ParamByName('tabel').AsString := WideString(Edit1.Text);  | 
| 
		 
			 
			#11  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Ага, как и предполагалось, где-то идет конвертация в AnsiString с неправильной кодовой страницей. Только вот я не ожидал, что она в параметрах происходит. 
		
	
		
		
		
		
		
	
		
		
	
	
	Кстати, переводить Edit1.Text в WideString, наверное, не обязательно. Дефолтный String, который на самом деле UnicodeString полностью совместим с WideString (собственно, это один и тот же тип). Т.о. можно сделать что-то типа: Код: 
	      GlavFrm.FDQuery1.SQL.Text := 'INSERT INTO Malimet (tabel, name, birthday, citizenship, nationality, gender, military_rank, photo, password) VALUES (:tabel, :name, :birthday, :citizenship, :nationality, :gender, :military_rank, :photo, :password)';
      For I := 0 To GlavFrm.FDQuery1.Params.Count-1 Do
        If GlavFrm.FDQuery1.Params[i].DataType = ftString Then
          GlavFrm.FDQuery1.Params[i].DataType := ftWideString;
      GlavFrm.FDQuery1.ParamByName('tabel').AsString := Edit1.Text;
      GlavFrm.FDQuery1.ParamByName('name').AsString := UTF8Encode(Edit2.Text);
      GlavFrm.FDQuery1.ParamByName('birthday').Value := DateTimePicker1.Date;
      GlavFrm.FDQuery1.ParamByName('citizenship').AsString := ComboBox1.Text;
      GlavFrm.FDQuery1.ParamByName('nationality').AsString := ComboBox2.Text;
      GlavFrm.FDQuery1.ParamByName('gender').AsString := ComboBox3.Text;
      GlavFrm.FDQuery1.ParamByName('military_rank').AsString := ComboBox4.Text;
      GlavFrm.FDQuery1.ParamByName('photo').AsString := label8.Caption;
      GlavFrm.FDQuery1.ParamByName('password').AsString := Edit3.Text;
      GlavFrm.FDQuery1.ExecSQL; | 
| Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
 
Aibekkoke (09.02.2024)
  | ||
| 
		 
			 
			#12  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Кстати, а какая кодовая страница стоит по умолчанию? 
		
	
		
		
		
		
		
		
			Посмотри значение в System.DefaultSystemCodePage Если неправильная, то вызови метод System.SetMultiByteConversionCodePage для установки правильной кодировки. Последний раз редактировалось Aristarh Dark, 04.03.2024 в 15:57.  |