Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/46: Рейтинг темы: голосов - 46, средняя оценка - 4.96
 Аватар для posthuman
10 / 10 / 2
Регистрация: 26.09.2009
Сообщений: 93

Кодировка БД

18.03.2011, 14:57. Показов 8873. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Тут такая проблема. Вывод файла в целом происходит нормально кроме одного момента.
При подключении к файла устанавливаю кодировку
PHP
1
2
3
mysql_query ("set character_set_client='cp1251'"); //кодировка, в которой данные будут поступать от клиента
mysql_query ("set character_set_results='cp1251'"); //кодировка, в которой будет выбран результат
mysql_query ("set collation_connection='cp1251_general_ci'"); //кодировка по умолчанию для всего, что в рамках соединения не имеет кодировки
или так
PHP
1
2
mysql_query('SET CHARACTER SET cp1251');
mysql_query('SET NAMES cp1251');
Фаил создан
HTML5
1
2
3
4
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251">
Создана форма
PHP
1
2
3
4
<form method="post" action="do_search.php">
<input type="text" name="search" id="search_box" class='search_box'/>
<input type="submit" value="Поиск" class="search_button" /><br />
</form>
В файле do_search.php присутствуют операторы выдачи русского текста и он отображается нормально. Но из базы данных русскоязычный текст выводится иероглифами. Сравнение в БД cp1251_general_ci. MySQL-кодировка: UTF-8 Unicode (utf8). Чтобы это могло быть?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.03.2011, 14:57
Ответы с готовыми решениями:

Кодировка программы и кодировка базы данных
В общем в архиве стандартный пример и одна из программ по редактированию sqlite. Проблема заклчается в следующем: при редактировании...

Кодировка
Есть html страница с php скриптом и php файл, который подключается к этой странице. Для страницы установлена в самом начале кодировка...

Кодировка
Проблема в следующем. Страничка на локальном компе видна с русскими букивками. При переносе на сервер русские букивки становяться непонятно...

7
 Аватар для posthuman
10 / 10 / 2
Регистрация: 26.09.2009
Сообщений: 93
20.03.2011, 11:34  [ТС]
есть какие то варианты?
0
 Аватар для Nazz
898 / 729 / 80
Регистрация: 12.03.2009
Сообщений: 2,804
Записей в блоге: 2
20.03.2011, 11:52
попробуйте перекодировать результат
PHP
1
$result = iconv('cp1251', 'utf8', $row['result']);
0
 Аватар для romchiksoad
1957 / 796 / 89
Регистрация: 03.11.2009
Сообщений: 3,066
Записей в блоге: 2
20.03.2011, 22:35
posthuman, скажите, что конкретно Вам не ясно после прочтения этой темы Базы Данных. Кодировка ввода/вывода. ?
0
 Аватар для posthuman
10 / 10 / 2
Регистрация: 26.09.2009
Сообщений: 93
20.03.2011, 22:50  [ТС]
впринципе все сделано как сказано, тока результат не тот.
0
601 / 569 / 104
Регистрация: 07.11.2010
Сообщений: 2,004
21.03.2011, 00:33
а что нельзя страницу в utf-8 сделать и не париться?
0
 Аватар для posthuman
10 / 10 / 2
Регистрация: 26.09.2009
Сообщений: 93
21.03.2011, 10:02  [ТС]
в utf8 русский текст не отображается. и поиск выводит не верный результат при вводе русских символов.

Добавлено через 25 минут
уже перепробовал все что можно, с разными кодировками либо идет отображение в Opera либо Chrome.
Вот механизм поиска, работает тока на латинские буквы.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?php
//получаем данные через $_POST
if (isset($_POST['search'])) {
    // подключаемся к базе
    include('db.php');
    $db = new db();
    // никогда не доверяйте входящим данным! Фильтруйте всё!
    $word = mysql_real_escape_string($_POST['search']);
    // Строим запрос
    $sql = "SELECT title FROM article WHERE title LIKE '%" . $word . "%' ORDER BY title LIMIT 10";
    // Получаем результаты
    $row = $db->select_list($sql);
    if(count($row)) {
        $end_result = '';
        foreach($row as $r) {
            $result         = $r['title'];
            $bold           = '<span class="found">' . $word . '</span>';
            $end_result     .= '<li>' . str_ireplace($word, $bold, $result) . '</li>';
        }
        echo $end_result;
    } else {
        echo '<li>По вашему запросу ничего не найдено</li>';
    }
}
?>
Вот подключение к бд и выбор кодировки.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<?php
  class db {
 
    function __construct()
    {
        global $dbh;
        if (!is_null($dbh)) return;
        $dbh = mysql_pconnect('localhost', 'road', '12345');
        mysql_select_db('web');
        
        mysql_query ("set character_set_client='cp1251'"); //кодировка, в которой данные будут поступать от клиента
        mysql_query ("set character_set_results='cp1251'"); //кодировка, в которой будет выбран результат
        mysql_query ("set collation_connection='cp1251_general_ci'"); //кодировка по умолчанию для всего, что в рамках соединения не имеет кодировки
        mysql_query('SET CHARACTER SET cp1251');
        mysql_query('SET NAMES cp1251');
    }
 
    function select_list($query)
    {
        $q = mysql_query($query);
        if (!$q) return null;
        $ret = array();
        while ($row = mysql_fetch_array($q, MYSQL_ASSOC)) {
            array_push($ret, $row);
        }
        mysql_free_result($q);
        return $ret;
    }
  }
?>
На самих страницах отображение идет верно, а при поиске либо не понятные символы, либо отображение правильное тока в Chrome.

Добавлено через 1 минуту
По русским символам поиск вообще не проходит.

Добавлено через 59 минут
если же сделать
PHP
1
2
mysql_query('SET NAMES utf8');
mysql_query('SET CHARACTER SET utf8');
то поиск работает совершенно нормально и с кирилицей в брауззере chrome, но остальные элементы страницы (заголовок, keywords, description) непонятными символами.

Добавлено через 18 минут
убрав при подключении все кодировки, и изменив
PHP
1
$dbh = mysql_pconnect('localhost', 'road', '12345');
на
PHP
1
$dbh = mysql_connect('localhost', 'road', '12345');
Отображение заголовкой идет нормально, но поиск по кириллице не работает.
0
601 / 569 / 104
Регистрация: 07.11.2010
Сообщений: 2,004
21.03.2011, 21:16
posthuman да ладно не отображается? я вот пишу с ним курсовой и все отлично работает и не надо заморачиваться с перекодировкой
вот попробуй [Ссылка удалена модератором!]
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.03.2011, 21:16
Помогаю со студенческими работами здесь

Кодировка
Привет всем. Проблема такая: заместо русских букв из базы данных MySQL выводятся знаки вопроса (&quot;??????&quot;, без чёрного фона). ...

Кодировка
Здравствуйте, знаю что тема была на форуме уже много раз, но свою проблему не нашел! Проблема такая: Делаю сайт, у меня не...

Кодировка
Все привет #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; //Прототипы функций void...

Кодировка
Добрый день! учусь программирование, совсем новичок. Помогите решить вопрос: Я хотел установить на сайте сортировку по типам и брендам...

Кодировка БД
В БД выводится неправильная раскладка. Да, я уже перечитала кучу сообщений на эту тему, кучу тем форумов и просто записей, но ничего не...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru