Db.php
1.58 KB
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
<?php
class LtDb
{
	public $configHandle;
	public $group;
	public $node;
	protected $dbh;
	public function __construct()
	{
		if (! $this->configHandle instanceof LtConfig)
		{
			if (class_exists("LtObjectUtil", false))
			{
				$this->configHandle = LtObjectUtil::singleton("LtConfig");
			}
			else
			{
				$this->configHandle = new LtConfig;
			}
		}
	}
	public function init()
	{
		$this->dbh = new LtDbHandle;
		$this->dbh->configHandle = $this->configHandle;
		$this->dbh->group = $this->getGroup();
		$this->dbh->node = $this->getNode();
		$this->dbh->init();
	}
	public function getDbHandle()
	{
		return $this->dbh;
	}
	public function getTDG($tableName)
	{
		$tg = new LtDbTableDataGateway;
		$tg->configHandle = $this->configHandle;
		$tg->tableName = $tableName;
		$tg->createdColumn = 'created';
		$tg->modifiedColumn = 'modified';
		$tg->dbh = $this->dbh;
		return $tg;
	}
	public function getSqlMapClient()
	{
		$smc = new LtDbSqlMapClient;
		$smc->configHandle = $this->configHandle;
		$smc->dbh = $this->dbh;
		return $smc;
	}
	public function changeNode($node)
	{
		$this->node = $node;
		$this->dbh->node = $node;
	}
	protected function getGroup()
	{
		if ($this->group)
		{
			return $this->group;
		}
		$servers = $this->configHandle->get("db.servers");
		if (1 == count($servers))
		{
			return key($servers);
		}
		return false;
	}
	protected function getNode()
	{
		if ($this->node)
		{
			return $this->node;
		}
		$servers = $this->configHandle->get("db.servers");
		if (1 == count($servers[$this->getGroup()]))
		{
			return key($servers[$this->getGroup()]);
		}
		return false;
	}
}