This repository has been archived by the owner on Dec 6, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclass.database.php
99 lines (82 loc) · 2.89 KB
/
class.database.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
<?php
/*======================================================================*\
|| #################################################################### ||
|| # PHP Utilities Alpha 2 # ||
|| # ---------------------------------------------------------------- # ||
|| # Useful Everyday PHP classes, that work as one! # ||
|| # ---------------------------------------------------------------- # ||
|| # All PHP code in this file is ©2014 VisionWare Studios # ||
|| # This script is released under The MIT License. # ||
|| # # ||
|| # --------------- PHP VERSION 5.5.0 OR GREATER ----------------- # ||
|| # # ||
|| # http://visionware-studios.com # ||
|| #################################################################### ||
\*======================================================================*/
class Database
{
private $_connection;
protected $_info;
protected $_last_query;
public $session;
public function __construct($server, $username, $password, $database, $port, $prefix = '')
{
$this->_info = array(
'Server' => $server,
'Username' => $username,
'Password' => $password,
'Database' => $database,
'Port' => $port,
'Prefix' => $prefix
);
if ( ! empty($this->_info['Prefix']))
{
$this->_info['Prefix'] = $this->_info['Prefix'] . '_';
}
$this->_connection = new mysqli(
$this->_info['Server'],
$this->_info['Username'],
$this->_info['Password'],
$this->_info['Database'],
$this->_info['Port']
);
if ($this->_connection->connect_error)
{
Error_Handle::GEN_ERROR('<strong>Error Connecting to MySQL:</strong> ' . $this->_connection->connect_error);
}
$this->session = new Session();
return $this->_info;
}
public function Connection()
{
return $this->_connection;
}
public function session()
{
return $this->session;
}
protected function escape($string)
{
return htmlspecialchars($string, ENT_QUOTES, 'UTF-8');
}
public function customQuery($sql)
{
$result = $this->Connection()->query($sql);
return $result;
}
protected function statement($sql, $params)
{
if ( ! $stmt = $this->Connection()->prepare($sql))
{
Error_Handle::GEN_ERROR('Prepare Failed: ' . $stmt->error);
return FALSE;
}
if ( ! empty($params)) call_user_func_array(array($stmt, 'bind_param'), refValues($params));
if ( ! $stmt->execute())
{
Error_Handle::GEN_ERROR('Execute Failed: ' . $stmt->error);
return FALSE;
}
return $stmt;
}
}