S2OJ/uoj/1/app/models/DB.php
ceabrobot 0ec962b4af feat(uoj/1/app): modify the DB operation to support PHP7
In order to support PHP7, change the way to operate database. PHP7
removed the mysql extension, so the old way to operate database is
not usable. This commit use a new way to operate database.

BREAKING CHANGE: the way to operate database has changed.
2018-09-20 17:38:21 +08:00

83 lines
2.2 KiB
PHP

<?php
class DB {
public static function init() {
global $uojMySQL;
$uojMySQL = new mysqli(UOJConfig::$data['database']['host'] . ':3306', UOJConfig::$data['database']['username'], UOJConfig::$data['database']['password'], UOJConfig::$data['database']['database']);
if($uojMySQL == null){
echo '-----------------------\n';
echo $uojMySQL->connect_errno;
echo '========================\n';
}
if (!$uojMySQL) {
echo 'There is something wrong with database >_<.... ' . mysqli_error($uojMySQL);
die();
}
}
public static function escape($str) {
global $uojMySQL;
return mysqli_real_escape_string($uojMySQL, $str);
}
public static function fetch($r, $opt = MYSQLI_ASSOC) {
global $uojMySQL;
return mysqli_fetch_array($r, $opt);
}
public static function query($q) {
global $uojMySQL;
return mysqli_query($uojMySQL, $q);
}
public static function update($q) {
global $uojMySQL;
return mysqli_query($uojMySQL, $q);
}
public static function insert($q) {
global $uojMySQL;
return mysqli_query($uojMySQL, $q);
}
public static function insert_id() {
global $uojMySQL;
return mysqli_insert_id($uojMySQL);
}
public static function delete($q) {
global $uojMySQL;
return mysqli_query($uojMySQL, $q);
}
public static function select($q) {
global $uojMySQL;
return mysqli_query($uojMySQL, $q);
}
public static function selectAll($q, $opt = MYSQLI_ASSOC) {
global $uojMySQL;
$res = array();
$qr = mysqli_query($uojMySQL, $q);
while ($row = mysqli_fetch_array($qr, $opt)) {
$res[] = $row;
}
return $res;
}
public static function selectFirst($q, $opt = MYSQLI_ASSOC) {
global $uojMySQL;
return mysqli_fetch_array(mysqli_query($uojMySQL, $q), $opt);
}
public static function selectCount($q) {
global $uojMySQL;
list($cnt) = mysqli_fetch_array(mysqli_query($uojMySQL, $q), MYSQLI_NUM);
return $cnt;
}
public static function checkTableExists($name) {
global $uojMySQL;
return DB::query("select 1 from $name") !== false;
}
public static function num_rows() {
global $uojMySQL;
return mysqli_num_rows($uojMySQL);
}
public static function affected_rows() {
global $uojMySQL;
return mysqli_affected_rows($uojMySQL);
}
}