Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309

Иероглифы в базе данных

04.02.2016, 15:20. Показов 861. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.А почему в базу данных отправляют иероглифы???
Страницы отображаются корректно, а в базе данных "каряки"
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.02.2016, 15:20
Ответы с готовыми решениями:

На 7 иероглифы как иероглифы а на XP вместо них квадраты
В программе есть Caption состоящий из китайских иероглифов, на семерке все нормально, а вот на XP вместо китайских иероглифов квадраты вот...

иероглифы в базу данных
Парни, проблема в иероглифах в базу данных при вводе в текстовом блоке русских букв, запись в базу данных идет примерно такая. Надпись:...

Доступ к базе данных на базе хранимых процедур MySQL из php
Добрый день возник вопрос по доступ к базе данных на базе хранимых процедур MySQL из php Из файла php подключаюсь к бд вот так ...

6
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
04.02.2016, 15:35
Скорее всего кодировка бд не верная. Или кодировка запросов.
В первом случае изменить кодировку бд на utf-8 general ci
Во втором явно указать кодировку запросов (зависит от драйвера который используете) пример:
PHP
1
$mysqli->set_charset("utf8")
0
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
04.02.2016, 15:48  [ТС]
В базе все верно, вот страница:

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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<? 
include ("lock.php");
 
function show_form(){ 
        // подключаем файл с настройками подключения к БД 
        require '../inc/connect.php'; 
 
        //делаем запрос к БД, на данный момент на следующие две строчки не стоит обращать внимание, объясню их потом, посокльку на данном этапе они еще не используются. 
        $result = mysql_query("SELECT * FROM pages WHERE id = '".$_GET['id']."';", $link); 
        $row = mysql_fetch_array($result); 
?><!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link rel="stylesheet" href="style.css">
</head>
<body>
    
<a href="/admin">Главная</a><br>
<a href="/admin/?id=new">Добавить новую страницу</a><br><hr>
<form action="" method="post">
Название страницы (title)<br>
<input class="area_message2" type="text" name="title" value="<?=htmlspecialchars(stripslashes($row['title']));?>" class="enter" size="79"><br><br>
Заголовок страницы (Meta - title)<br> 
<input class="area_message2" type="text" name="metatitle" value="<?=htmlspecialchars(stripslashes($row['metatitle']));?>" class="enter" size="79"><br><br>
Ключевые слова (Meta - keywords)<br> 
<input class="area_message2" type="text" name="metakeywords" class="enter" size="79" value="<?=htmlspecialchars(stripslashes($row['metakeywords']));?>"><br><br>
Описание (Meta - description)<br> 
<input class="area_message2" type="text" name="metadescription" class="enter" size="79" value="<?=htmlspecialchars(stripslashes($row['metadescription']));?>"><br><br>
Текст страницы<br>
<textarea class="area_message" name="body" rows="20" class="enter"><?=stripslashes($row['body']);?></textarea><br><br>
<input type="hidden" name="id" value="<?=$_GET['id'];?>"><input type="submit" value="сохранить" name="edit"> 
</form> 
 
</body>
</html>
 
<? 
} // функция show_form() закончилась 
function complete(){ 
      // подключаем файл с настройками подключения - это мы уже знаем. 
      require '../inc/connect.php'; 
 
      // делаем запрос к БД в котором пытаемся вытащить страничку с указаным id. На данный момент мы не сделали еще ни одной страницы, посему запрос вернет пустой ряд. 
      $result = mysql_query("SELECT * FROM pages WHERE id = '".$_POST['id']."';", $link); 
 
      // перекидываем данные из MySQL в пхпшный ассоциативный массив 
      $row = mysql_fetch_array($result); 
 
      // проверяем не пуст ли элемент массива id. Если пуст, значит вставляем наши данные в БД 
      if(empty($row['id'])) 
            $query = "INSERT INTO pages 
                     (body, 
                      title, 
                      metatitle, 
                      metakeywords, 
                      metadescription) 
                                      VALUES 
                            ('".mysql_real_escape_string($_POST['body'])."', 
                             '".mysql_real_escape_string($_POST['title'])."', 
                             '".mysql_real_escape_string($_POST['metatitle'])."', 
                             '".mysql_real_escape_string($_POST['metakeywords'])."', 
                             '".mysql_real_escape_string($_POST['metadescription'])."')"; 
      // а вот если не пуст, значит с этим id уже есть запись и в данном случае мы ее просто отредактируем 
      else 
            $query = "UPDATE pages SET 
                                     body = '".mysql_real_escape_string($_POST['body'])."', 
                                     title = '".mysql_real_escape_string($_POST['title'])."', 
                                     metatitle = '".mysql_real_escape_string($_POST['metatitle'])."', 
                                     metakeywords = '".mysql_real_escape_string($_POST['metakeywords'])."', 
                                     metadescription = '".mysql_real_escape_string($_POST['metadescription'])."' 
                     WHERE id = '".$_POST['id']."';"; 
 
      // непосредственно записываем наши данные в базу (до этого мы просто описывали, что надо сделать, а теперь делаем) 
      mysql_query($query, $link); 
 
      // ну и просто выводим крикливую надпись, что скрипт отработал 
      echo '<h3>Данные сохранены</h3>'; 
} 
function show_pages() { 
// добавляем javascript, который позволит перед удалением спросить пользователя, уверен ли он в этом. 
?> 
<script language='JavaScript1.1' type='text/javascript'> 
<!-- 
function Delete(N) 
{ 
     if(confirm("Удалить запись?")) 
     { 
                 parent.location='?del='+N; 
     } 
     else 
     { 
       return false; 
     } 
} 
--> 
</SCRIPT> 
<? 
        require '../inc/connect.php'; 
        echo ' 
<a href="?id=new">Добавить страницу</a><br><hr>'; 
        echo ' 
<table cellspacing="1" cellpadding="2" bgcolor="#1F2760"> 
<tr bgcolor="#B0ADC3"> 
  <td colspan="2"> 
     <b>Название страницы</b> 
  </td> 
</tr>'; 
        $result = mysql_query("SELECT * FROM pages ORDER BY id;", $link); 
        while($row = mysql_fetch_array($result)){ 
               echo ' 
<tr bgcolor="#ffffff"> 
  <td> 
     <a href="?id='.$row['id'].'">'.stripslashes($row['title']).'</a> 
  </td> 
  <td> 
     <a href="#" title="Страница будет удалена без восстановления" OnClick="Delete('.$row['id'].')">удалить</a> 
  </td> 
</tr>'; 
         // добавили ячейку с ссылкой на удаление и не забыли вставить colspan="2" у заглавной ячейки 
         // думаю вы заметили, что в тексте ссылки мы заменили $row{'id'] на $row['title'] и добавили обработку функцией stripslashes() 
        } 
        echo ' 
</table>'; 
 
} 
function delete_pages(){ 
        require '../inc/connect.php'; 
        $query = "DELETE FROM pages WHERE id = '".$_GET['del']."';"; 
        mysql_query($query, $link); 
        echo '<h3>Данные удалены</h3>'; 
} 
if($_GET['del']) delete_pages(); 
if($_POST['edit']) complete(); // если была нажата кнопочка "отправить", которая именуется edit - тогда вызываем функию complete() 
if($_GET['id']) show_form(); // если мы нажали на ссылку в функции show_pages(), то значит мы передали в переменную $_GET['id'] тот самый id, который нас интересует. Поэтому в этом слчае вызываем форму редактирования нашей странички. 
else show_pages(); // ну, а если мы не выбрали определенный id - запускаем нашу функцию выбора id. 
?>
0
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
04.02.2016, 16:13
Не стал подробно рассматривать ваш код, вот после подключения напишите:
PHP
1
2
3
mysql_connect(****); // Ваше подключение к бд
mysql_set_charset( 'utf8' );
mysql_query ("SET NAMES utf8");
1
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
04.02.2016, 16:39  [ТС]
Спасибо большое
0
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
04.02.2016, 16:40
Получилось?
0
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
04.02.2016, 21:18  [ТС]
Да да, все четко.Спасибо еще раз.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.02.2016, 21:18
Помогаю со студенческими работами здесь

Записи в базе данных, как встать на последнюю запись в базе после открытия?
Есть два вопроса. Во-первых - как встать на последнюю запись в базе после открытия? И во-вторых - есть база в которую каждые 10...

Чтение файла: иероглифы вместо данных
Открываю файл вот таким кодом stringw strbuff; int numbytes = 0; long HTTPBUFLEN = 1000L; TCHAR httpbuff; CFile...

Иероглифы при работе с базой данных!
Здравствуйте! На главной странице есть 2 текста - первый который был прописан в HTML коде, а второй берётся с базы данных. Вот...

передача данных USART + DMA и непонятные иероглифы
Всем привет! Есть проблема с передачей данных с МК на ПК через USORT + DMA. Ранее все работало отлично, но с какого-то момента, а...

Иероглифы при экспорте данных из таблицы StringGrid в файл
Пишу программу, выполняющую расчёты по заданным в программе формулам, используя данные, которые загружаются из XML-файлов. На...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru