-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
mfwDBIBase.php
71 lines (65 loc) · 1.79 KB
/
mfwDBIBase.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
<?php
class mfwDBIBase {
/**
* make prepared statement.
* @param[in] $sql 実行するSQL
* @param[in] $con DB connection (PDO)
* @return PDOStatement
*/
public static function prepare($sql, PDO $con=null)
{
if(!$con){
$con = mfwDBConnection::getPDO();
}
return $con->prepare($sql);
}
/**
* SQL実行して、実行後のPDOStatementを返す.
* @param[in] $sql 実行するSQL文
* @param[in] $bind バインドする配列
* @param[in] $con DB connection (PDO)
* @return PDOStatement
*/
public static function query($sql, $bind=array(), PDO $con=null)
{
$stmt = static::prepare($sql,$con);
$stmt->execute($bind);
return $stmt;
}
/**
* SQL実行して、先頭一行を取得する.
* @param[in] $sql 実行するSQL文
* @param[in] $bind バインドする配列
* @param[in] $con DB connection (PDO)
* @return 行の連想配列
*/
public static function getRow($sql, $bind=array(), PDO $con=null)
{
$query = static::query($sql,$bind,$con);
return $query->fetch(PDO::FETCH_ASSOC);
}
/**
* SQL実行して、多次元連想配列で取得する.
* @param[in] $sql 実行するSQL文
* @param[in] $bind バインドする配列
* @param[in] $con DB connection
* @return 行の連想配列の配列
*/
public static function getAll($sql, $bind=array(), PDO $con=null)
{
$query = static::query($sql,$bind,$con);
return $query->fetchAll(PDO::FETCH_ASSOC);
}
/**
* SQL実行して、先頭行の先頭カラムの値のみを取得.
* @param[in] $sql 実行するSQL
* @param[in] $bind バインドする配列
* @param[in] $con DB connection (PDO)
* @return カラムの値
*/
public static function getOne($sql, $bind=array(), PDO $con=null)
{
$query = static::query($sql,$bind,$con);
return $query->fetchColumn(0);
}
}