DatabaseDao.class.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329
  1. <?php
  2. /**
  3. * @name eolinker ams open source,eolinker开源版本
  4. * @link https://www.eolinker.com/
  5. * @package eolinker
  6. * @author www.eolinker.com 广州银云信息科技有限公司 ©2015-2018
  7. * eoLinker是目前全球领先、国内最大的在线API接口管理平台,提供自动生成API文档、API自动化测试、Mock测试、团队协作等功能,旨在解决由于前后端分离导致的开发效率低下问题。
  8. * 如在使用的过程中有任何问题,欢迎加入用户讨论群进行反馈,我们将会以最快的速度,最好的服务态度为您解决问题。
  9. *
  10. * eoLinker AMS开源版的开源协议遵循Apache License 2.0,如需获取最新的eolinker开源版以及相关资讯,请访问:https://www.eolinker.com/#/os/download
  11. *
  12. * 官方网站:https://www.eolinker.com/
  13. * 官方博客以及社区:http://blog.eolinker.com/
  14. * 使用教程以及帮助:http://help.eolinker.com/
  15. * 商务合作邮箱:market@eolinker.com
  16. * 用户讨论QQ群:284421832
  17. */
  18. class DatabaseDao
  19. {
  20. /**
  21. * add database
  22. * 添加数据库
  23. * @param $dbName string 数据库名
  24. * @param $dbVersion string 数据库版本,默认1.0
  25. * @param $userID int 用户ID
  26. * @return int|bool
  27. */
  28. public function addDatabase(&$dbName, &$dbVersion, &$userID)
  29. {
  30. $db = getDatabase();
  31. $db->beginTransaction();
  32. $db->prepareExecute('INSERT INTO eo_database (eo_database.dbName,eo_database.dbVersion,eo_database.dbUpdateTime) VALUE (?,?,?);', array(
  33. $dbName,
  34. $dbVersion,
  35. date('Y-m-d H:i:s', time())
  36. ));
  37. if ($db->getAffectRow() < 1) {
  38. $db->rollback();
  39. return FALSE;
  40. }
  41. $dbID = $db->getLastInsertID();
  42. // 生成数据库与用户的联系
  43. $db->prepareExecute('INSERT INTO eo_conn_database (eo_conn_database.dbID,eo_conn_database.userID) VALUES (?,?);', array(
  44. $dbID,
  45. $userID
  46. ));
  47. if ($db->getAffectRow() < 1) {
  48. $db->rollback();
  49. return FALSE;
  50. } else {
  51. $db->commit();
  52. return $dbID;
  53. }
  54. }
  55. /**
  56. * check database permission
  57. * 检查数据库跟用户是否匹配
  58. * @param $dbID int 数据库ID
  59. * @param $userID int 用户ID
  60. * @return bool|int
  61. */
  62. public function checkDatabasePermission(&$dbID, &$userID)
  63. {
  64. $db = getDatabase();
  65. $result = $db->prepareExecute('SELECT eo_conn_database.dbID FROM eo_conn_database WHERE eo_conn_database.dbID = ? AND eo_conn_database.userID = ?;', array(
  66. $dbID,
  67. $userID
  68. ));
  69. if (empty($result))
  70. return FALSE;
  71. else
  72. return $result['dbID'];
  73. }
  74. /**
  75. * delete database
  76. * 删除数据库
  77. * @param $dbID int 数据库ID
  78. * @return bool
  79. */
  80. public function deleteDatabase(&$dbID)
  81. {
  82. $db = getDatabase();
  83. $db->prepareExecute('DELETE FROM eo_database WHERE eo_database.dbID = ?;', array(
  84. $dbID
  85. ));
  86. if ($db->getAffectRow() < 1) {
  87. return FALSE;
  88. } else
  89. return TRUE;
  90. }
  91. /**
  92. * get database list
  93. * 获取数据库列表
  94. * @param $userID int 用户ID
  95. * @return array|bool
  96. */
  97. public function getDatabase(&$userID)
  98. {
  99. $db = getDatabase();
  100. $result = $db->prepareExecuteAll('SELECT eo_database.dbID,eo_database.dbName,eo_database.dbVersion,eo_database.dbUpdateTime,eo_conn_database.userType FROM eo_database INNER JOIN eo_conn_database ON eo_database.dbID = eo_conn_database.dbID WHERE eo_conn_database.userID = ?;', array(
  101. $userID
  102. ));
  103. if (empty($result))
  104. return FALSE;
  105. else
  106. return $result;
  107. }
  108. /**
  109. * edit database
  110. * 修改数据库
  111. * @param $dbID int 数据库ID
  112. * @param $dbName string 数据库名
  113. * @param $dbVersion string 数据库版本
  114. * @return bool
  115. */
  116. public function editDatabase(&$dbID, &$dbName, &$dbVersion)
  117. {
  118. $db = getDatabase();
  119. $db->prepareExecute('UPDATE eo_database SET eo_database.dbName = ?,eo_database.dbVersion =?,eo_database.dbUpdateTime =? WHERE eo_database.dbID =?;', array(
  120. $dbName,
  121. $dbVersion,
  122. date('Y-m-d H:i:s', time()),
  123. $dbID
  124. ));
  125. if ($db->getAffectRow() < 1) {
  126. return FALSE;
  127. } else
  128. return TRUE;
  129. }
  130. /**
  131. * Import database table which export from mysql
  132. * 导入数据表
  133. * @param $dbID int 数据库ID
  134. * @param $tableList array 数据库表
  135. * @return bool
  136. */
  137. public function importDatabase(&$dbID, &$tableList)
  138. {
  139. $db = getDatabase();
  140. try {
  141. $db->beginTransaction();
  142. foreach ($tableList as $table) {
  143. $db->prepareExecute('INSERT INTO eo_database_table (eo_database_table.dbID,eo_database_table.tableName,eo_database_table.tableDescription) VALUES (?,?,?);', array(
  144. $dbID,
  145. $table['tableName'],
  146. $table['tableDesc']
  147. ));
  148. if ($db->getAffectRow() < 1) {
  149. throw new \PDOException("add databaseTable error");
  150. }
  151. $tableID = $db->getLastInsertID();
  152. foreach ($table['fieldList'] as $field) {
  153. $db->prepareExecute('INSERT INTO eo_database_table_field (eo_database_table_field.tableID,eo_database_table_field.fieldName,eo_database_table_field.fieldType,eo_database_table_field.fieldLength,eo_database_table_field.isNotNull,eo_database_table_field.isPrimaryKey,eo_database_table_field.fieldDescription) VALUES (?,?,?,?,?,?,?);', array(
  154. $tableID,
  155. $field['fieldName'],
  156. $field['fieldType'],
  157. $field['fieldLength'],
  158. $field['isNotNull'],
  159. $field['isPrimaryKey'],
  160. $field['fieldDesc']
  161. ));
  162. if ($db->getAffectRow() < 1) {
  163. throw new \PDOException("add databaseTableField error");
  164. }
  165. }
  166. }
  167. } catch (\PDOException $e) {
  168. $db->rollBack();
  169. return FALSE;
  170. }
  171. $db->commit();
  172. return TRUE;
  173. }
  174. /**
  175. * get database info
  176. * 获取数据库信息
  177. * @param $dbID int 数据库ID
  178. * @return array|bool
  179. */
  180. public function getDatabaseInfo(&$dbID)
  181. {
  182. $db = getDatabase();
  183. $dumpJson = array();
  184. // 获取数据库信息
  185. $dumpJson['databaseInfo'] = $db->prepareExecute("SELECT eo_database.dbName AS databaseName,eo_database.dbVersion AS databaseVersion FROM eo_database WHERE eo_database.dbID = ?;", array(
  186. $dbID
  187. ));
  188. // 获取数据库表信息
  189. $table_list = $db->prepareExecuteAll("SELECT tableID,tableName AS tableName, tableDescription AS tableDesc FROM eo_database_table WHERE eo_database_table.dbID = ?;", array(
  190. $dbID
  191. ));
  192. $dumpJson['tableList'] = array();
  193. $i = 0;
  194. foreach ($table_list as $table) {
  195. $dumpJson['tableList'][$i] = $table;
  196. // 获取字段信息
  197. $field_list = $db->prepareExecuteAll("SELECT fieldName,fieldType,fieldLength,isNotNull,isPrimaryKey,fieldDescription AS fieldDesc,defaultValue FROM eo_database_table_field WHERE eo_database_table_field.tableID = ?;", array(
  198. $table['tableID']
  199. ));
  200. $dumpJson['tableList'][$i]['fieldList'] = array();
  201. $j = 0;
  202. foreach ($field_list as $field_list) {
  203. $dumpJson['tableList'][$i]['fieldList'][$j] = $field_list;
  204. ++$j;
  205. }
  206. ++$i;
  207. }
  208. if (!empty($dumpJson))
  209. return $dumpJson;
  210. else
  211. return FALSE;
  212. }
  213. /**
  214. * update database update time
  215. * 更新数据库更新时间
  216. * @param $dbID int 数据库ID
  217. */
  218. public function updateDatabaseUpdateTime(&$dbID)
  219. {
  220. $db = getDatabase();
  221. $db->prepareExecute('UPDATE eo_database SET eo_database.dbUpdateTime =? WHERE eo_database.dbID =?;', array(
  222. date('Y-m-d H:i:s', time()),
  223. $dbID
  224. ));
  225. }
  226. /**
  227. * Import database by database's data which export from the api named exportDatabase
  228. * 导入数据字典界面数据库
  229. * @param $userID int 用户ID
  230. * @param $data string 数据库相关数据
  231. * @return bool
  232. */
  233. public function importDatabaseByJson(&$userID, &$data)
  234. {
  235. $db = getDatabase();
  236. try {
  237. // 开始事务
  238. $db->beginTransaction();
  239. // 生成数据库
  240. $db->prepareExecute("INSERT INTO eo_database(eo_database.dbName,eo_database.dbVersion,eo_database.dbUpdateTime)VALUES(?,?,?);", array(
  241. $data['databaseInfo']['databaseName'],
  242. $data['databaseInfo']['databaseVersion'],
  243. date('Y-m-d H:i:s', time())
  244. ));
  245. if ($db->getAffectRow() < 1) {
  246. throw new \PDOException('insert database error');
  247. }
  248. $dbID = $db->getLastInsertID();
  249. // 生成数据库与用户的联系
  250. $db->prepareExecute('INSERT INTO eo_conn_database (eo_conn_database.dbID,eo_conn_database.userID) VALUES (?,?);', array(
  251. $dbID,
  252. $userID
  253. ));
  254. if ($db->getAffectRow() < 1) {
  255. throw new \PDOException('insert conn error');
  256. }
  257. foreach ($data['tableList'] as $table) {
  258. // 生成数据库表
  259. $db->prepareExecute("INSERT INTO eo_database_table(eo_database_table.dbID,eo_database_table.tableName,eo_database_table.tableDescription)VALUES(?,?,?);", array(
  260. $dbID,
  261. $table['tableName'],
  262. $table['tableDesc']
  263. ));
  264. if ($db->getAffectRow() < 1) {
  265. throw new \PDOException('insert table error');
  266. }
  267. $table_id = $db->getLastInsertID();
  268. foreach ($table['fieldList'] as $field) {
  269. // 生成字段表
  270. $db->prepareExecute("INSERT INTO eo_database_table_field(eo_database_table_field.fieldName,eo_database_table_field.fieldType,eo_database_table_field.fieldLength,eo_database_table_field.isNotNull,eo_database_table_field.isPrimaryKey,eo_database_table_field.fieldDescription,eo_database_table_field.tableID,eo_database_table_field.defaultValue)VALUES(?,?,?,?,?,?,?,?);", array(
  271. $field['fieldName'],
  272. $field['fieldType'],
  273. $field['fieldLength'],
  274. $field['isNotNull'],
  275. $field['isPrimaryKey'],
  276. $field['fieldDesc'],
  277. $table_id,
  278. $field['defaultValue']
  279. ));
  280. if ($db->getAffectRow() < 1) {
  281. throw new \PDOException('insert field error');
  282. }
  283. }
  284. }
  285. } catch (\PDOException $e) {
  286. // 出错回滚
  287. $db->rollBack();
  288. return FALSE;
  289. }
  290. // 提交更改
  291. $db->commit();
  292. return TRUE;
  293. }
  294. }
  295. ?>