DatabaseTableFieldDao.class.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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 DatabaseTableFieldDao
  19. {
  20. /**
  21. * 添加字段
  22. * @param $tableID int 数据表ID
  23. * @param $fieldName string 字段名
  24. * @param $fieldType string 字段类型
  25. * @param $fieldLength int 字段长度
  26. * @param $isNotNull int 是否非空 [0/1]=>[否/是],默认为0
  27. * @param $isPrimaryKey int 是否为主键 [0/1]=>[否/是],默认为0
  28. * @param $fieldDesc string 字段描述,默认为NULL
  29. * @return bool|int
  30. */
  31. public function addField(&$tableID, &$fieldName, &$fieldType, &$fieldLength, &$isNotNull, &$isPrimaryKey, &$fieldDesc, &$defaultValue)
  32. {
  33. $db = getDatabase();
  34. $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,eo_database_table_field.defaultValue) VALUES (?,?,?,?,?,?,?,?);', array(
  35. $tableID,
  36. $fieldName,
  37. $fieldType,
  38. $fieldLength,
  39. $isNotNull,
  40. $isPrimaryKey,
  41. $fieldDesc,
  42. $defaultValue
  43. ));
  44. if ($db->getAffectRow() < 1)
  45. return FALSE;
  46. else
  47. return $db->getLastInsertID();
  48. }
  49. /**
  50. * 检查字段与用户是否匹配
  51. * @param $fieldID int 字段ID
  52. * @param $userID int 用户ID
  53. * @return bool|int
  54. */
  55. public function checkFieldPermission($fieldID, $userID)
  56. {
  57. $db = getDatabase();
  58. $result = $db->prepareExecute('SELECT eo_database_table.dbID FROM eo_database_table INNER JOIN eo_database_table_field ON eo_database_table.tableID = eo_database_table_field.tableID INNER JOIN eo_conn_database ON eo_database_table.dbID = eo_conn_database.dbID WHERE eo_database_table_field.fieldID = ? AND eo_conn_database.userID =?;', array(
  59. $fieldID,
  60. $userID
  61. ));
  62. if (empty($result))
  63. return FALSE;
  64. else
  65. return $result['dbID'];
  66. }
  67. /**
  68. * 删除字段
  69. * @param $fieldID int 字段ID
  70. * @return bool
  71. */
  72. public function deleteField(&$fieldID)
  73. {
  74. $db = getDatabase();
  75. $db->prepareExecute('DELETE FROM eo_database_table_field WHERE eo_database_table_field.fieldID =?;', array($fieldID));
  76. if ($db->getAffectRow() < 1)
  77. return FALSE;
  78. else
  79. return TRUE;
  80. }
  81. /**
  82. * 获取字段列表
  83. * @param $tableID int 数据表ID
  84. * @return bool|array
  85. */
  86. public function getField(&$tableID)
  87. {
  88. $db = getDatabase();
  89. $result = $db->prepareExecuteAll('SELECT eo_database_table_field.tableID,eo_database_table_field.fieldID,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.defaultValue FROM eo_database_table_field WHERE eo_database_table_field.tableID = ?;', array($tableID));
  90. if (empty($result))
  91. return FALSE;
  92. else
  93. return $result;
  94. }
  95. /**
  96. * 修改字段
  97. * @param $fieldID int 字段ID
  98. * @param $fieldName string 字段名
  99. * @param $fieldType string 字段类型
  100. * @param $fieldLength int 字段长度
  101. * @param $isNotNull int 是否非空 [0/1]=>[否/是],默认为0
  102. * @param $isPrimaryKey int 是否为主键 [0/1]=>[否/是],默认为0
  103. * @param $fieldDesc string 字段描述,默认为NULL
  104. * @param $defaultValue string 默认值
  105. * @return bool
  106. */
  107. public function editField(&$fieldID, &$fieldName, &$fieldType, &$fieldLength, &$isNotNull, &$isPrimaryKey, &$fieldDesc, $defaultValue)
  108. {
  109. $db = getDatabase();
  110. $db->prepareExecute('UPDATE eo_database_table_field SET 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.defaultValue =? WHERE eo_database_table_field.fieldID =?;', array(
  111. $fieldName,
  112. $fieldType,
  113. $fieldLength,
  114. $isNotNull,
  115. $isPrimaryKey,
  116. $fieldDesc,
  117. $defaultValue,
  118. $fieldID
  119. ));
  120. if ($db->getAffectRow() < 1)
  121. return FALSE;
  122. else
  123. return TRUE;
  124. }
  125. }
  126. ?>