DatabaseTableDao.class.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  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 DatabaseTableDao
  19. {
  20. /**
  21. * 添加表
  22. * @param $dbID int 数据库ID
  23. * @param $tableName string 表名称
  24. * @param $tableDesc string 表描述
  25. * @return bool
  26. */
  27. public function addTable(&$dbID, &$tableName, &$tableDesc)
  28. {
  29. $db = getDatabase();
  30. $db->prepareExecute('INSERT INTO eo_database_table (eo_database_table.dbID,eo_database_table.tableName,eo_database_table.tableDescription) VALUES (?,?,?);', array(
  31. $dbID,
  32. $tableName,
  33. $tableDesc
  34. ));
  35. if ($db->getAffectRow() < 1) {
  36. return FALSE;
  37. } else
  38. return $db->getLastInsertID();
  39. }
  40. /**
  41. * 检查数据表权限
  42. * @param $tableID int 表ID
  43. * @param $userID int 用户ID
  44. * @return bool
  45. */
  46. public function checkTablePermission(&$tableID, &$userID)
  47. {
  48. $db = getDatabase();
  49. $result = $db->prepareExecute('SELECT eo_database.dbID FROM eo_database_table INNER JOIN eo_database ON eo_database_table.dbID = eo_database.dbID INNER JOIN eo_conn_database ON eo_database.dbID = eo_conn_database.dbID WHERE eo_database_table.tableID =? AND eo_conn_database.userID =?;', array(
  50. $tableID,
  51. $userID
  52. ));
  53. if (empty($result))
  54. return FALSE;
  55. else
  56. return $result['dbID'];
  57. }
  58. /**
  59. * 删除表
  60. * @param $tableID int 表ID
  61. * @return bool
  62. */
  63. public function deleteTable(&$tableID)
  64. {
  65. $db = getDatabase();
  66. $db->prepareExecute('DELETE FROM eo_database_table WHERE eo_database_table.tableID = ?;', array($tableID));
  67. if ($db->getAffectRow() < 1)
  68. return FALSE;
  69. else
  70. return TRUE;
  71. }
  72. /**
  73. * 获取表列表
  74. * @param $dbID int 数据库ID
  75. * @return bool
  76. */
  77. public function getTable(&$dbID)
  78. {
  79. $db = getDatabase();
  80. $result = $db->prepareExecuteAll('SELECT eo_database_table.dbID,eo_database_table.tableID,eo_database_table.tableName,eo_database_table.tableDescription FROM eo_database_table WHERE eo_database_table.dbID =? ORDER BY eo_database_table.tableName;', array($dbID));
  81. if (empty($result))
  82. return FALSE;
  83. else
  84. return $result;
  85. }
  86. /**
  87. * 编辑表
  88. * @param $tableID int 表ID
  89. * @param $tableName string 表名称
  90. * @param $tableDesc string 表描述
  91. * @return bool
  92. */
  93. public function editTable(&$tableID, &$tableName, &$tableDesc)
  94. {
  95. $db = getDatabase();
  96. $db->prepareExecute('UPDATE eo_database_table SET eo_database_table.tableName = ?,eo_database_table.tableDescription = ? WHERE eo_database_table.tableID = ?;', array(
  97. $tableName,
  98. $tableDesc,
  99. $tableID
  100. ));
  101. if ($db->getAffectRow() < 1)
  102. return FALSE;
  103. else
  104. return TRUE;
  105. }
  106. }
  107. ?>