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

Кодировка БД

18.03.2011, 14:57. Показов 8838. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru