-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmysql.php
120 lines (106 loc) · 3.21 KB
/
mysql.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
<?php
require_once("config.php");
class SBMySQL
{
private $link;
////
// Конструктор
// Подключение к MySQL
public function __construct(){
// from config.php
global $Config;
// Connect to MySQL
$this->link = mysql_connect(
$Config->getHostDB() . ":" . $Config->getPortDB(),
$Config->getUserDB(),
$Config->getPasswordDB()
) or die (mysql_error ());
// Connect to data base
mysql_select_db(
$Config->getNameDB(),
$this->link
) or die(mysql_error());
// Setting charset
mysql_set_charset($Config->getCharset(), $this->link);
}
////
// Деструктор
public function __destruct(){
mysql_close($this->link);
}
////
// Вспомогательная функция. Возвращает массив со всеми значениями ответа БД
private function getArrayByQuery($query){
$array = [];
$i = 0;
while($result = mysql_fetch_assoc($query)){
$array[$i] = $result;
$i++;
}
return $array;
}
////
// Показывает новости
public function getPosts($count=10, $offset=0){
$query = mysql_query("SELECT * FROM posts ORDER BY id DESC LIMIT $count OFFSET $offset");
return $this->getArrayByQuery($query);
}
////
// Новость по ID
public function getPostByID($id){
$query = mysql_query("SELECT * FROM posts WHERE id='$id'");
return mysql_fetch_assoc($query);
}
////
// Поиск
public function getPostsBySubstring($text) {
$query = mysql_query("SELECT * FROM posts
WHERE title LIKE '%$text%'
OR content LIKE '%$text%'
OR category LIKE '%$text%'
ORDER BY id DESC");
return $this->getArrayByQuery($query);
}
////
// Показывает новости по выбранной категории
public function getPostsByCat($category){
$query = mysql_query("SELECT * FROM posts WHERE category='$category' ORDER BY id DESC");
return $this->getArrayByQuery($query);
}
////
// Выдает список всех категорий
public function getCategories(){
$query = mysql_query("SELECT DISTINCT category FROM posts ORDER BY category");
return $this->getArrayByQuery($query);
}
////
// Добавление новости
public function PostAdd($title, $content, $category) {
$title = mysql_escape_string($title);
$content = mysql_escape_string($content);
$category = mysql_escape_string($category);
mysql_query("INSERT INTO posts (title, content, category)
VALUES ('$title', '$content', '$category')");
}
////
// Редактирование новости
public function PostUpdate($id, $title, $content, $category) {
mysql_query("UPDATE posts
SET title='$title', content='$content', category='$category'
WHERE id='$id'");
}
////
// Удаление новости
public function PostDelete($id) {
mysql_query("DELETE FROM posts WHERE id='$id'");
}
////
// Количество новостей
public function getPostsCount() {
$query = mysql_query("SELECT COUNT(*) FROM posts");
return mysql_fetch_row($query)[0];
}
}
// Создаем единственный экземпляр БД
$DataBase = new SBMySQL();
?>