2
0

update.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <?php
  2. /*
  3. 向句子库中插入或更新数据
  4. */
  5. include("../log/pref_log.php");
  6. require_once "../config.php";
  7. require_once "../public/_pdo.php";
  8. require_once "../public/function.php";
  9. require_once "../usent/function.php";
  10. require_once "../channal/function.php";
  11. require_once "../ucenter/active.php";
  12. require_once __DIR__."/../public/snowflakeid.php";
  13. $snowflake = new SnowFlakeId();
  14. #检查是否登陆
  15. if (!isset($_COOKIE["userid"])) {
  16. $respond["status"] = 1;
  17. $respond["message"] = 'not login';
  18. echo json_encode($respond, JSON_UNESCAPED_UNICODE);
  19. exit;
  20. }
  21. if (isset($_POST["landmark"])) {
  22. $_landmark = $_POST["landmark"];
  23. } else {
  24. $_landmark = "";
  25. }
  26. $aData = json_decode($_POST["data"], true);
  27. PDO_Connect(_FILE_DB_SENTENCE_,_DB_USERNAME_, _DB_PASSWORD_);
  28. //查询没有id的哪些是数据库里已经存在的,防止多次提交同一条记录造成一个句子 多个channal
  29. $newList = array();
  30. $new_id = array();
  31. $oldList = array();
  32. $query = "SELECT uid FROM "._TABLE_SENTENCE_." WHERE book_id = ? and paragraph = ? and word_start = ? and word_end = ? and channel_uid = ? limit 1 ";
  33. foreach ($aData as $data) {
  34. if (!isset($data["id"]) || empty($data["id"])) {
  35. $id = PDO_FetchOne($query, array($data["book"],
  36. $data["paragraph"],
  37. $data["begin"],
  38. $data["end"],
  39. $data["channal"],
  40. ));
  41. if (empty($id)) {
  42. $newList[] = $data;
  43. } else {
  44. $data["id"] = $id;
  45. $oldList[] = $data;
  46. }
  47. } else {
  48. $oldList[] = $data;
  49. }
  50. }
  51. $update_list = array(); //已经成功修改数据库的数据 回传客户端
  52. /* 修改现有数据 */
  53. if (count($oldList) > 0) {
  54. add_edit_event(_SENT_EDIT_, "{$oldList[0]["book"]}-{$oldList[0]["paragraph"]}-{$oldList[0]["begin"]}-{$oldList[0]["end"]}@{$oldList[0]["channal"]}");
  55. $PDO->beginTransaction();
  56. $query = "UPDATE "._TABLE_SENTENCE_." SET content= ? , status = ? , strlen = ? , modify_time= ? , updated_at=now() where uid= ? ";
  57. $sth = $PDO->prepare($query);
  58. foreach ($oldList as $data) {
  59. if (isset($data["id"])) {
  60. if (isset($data["time"])) {
  61. $modify_time = $data["time"];
  62. } else {
  63. $modify_time = mTime();
  64. }
  65. $sth->execute(array($data["text"], $data["status"], mb_strlen($data["text"], "UTF-8"), mTime(), $data["id"]));
  66. }
  67. }
  68. $PDO->commit();
  69. $respond = array("status" => 0, "message" => "", "insert_error" => "", "new_list" => array());
  70. if (!$sth || ($sth && $sth->errorCode() != 0)) {
  71. /* 识别错误且回滚更改 */
  72. $PDO->rollBack();
  73. $error = PDO_ErrorInfo();
  74. $respond['status'] = 1;
  75. $respond['message'] = $error[2];
  76. } else {
  77. #没错误 添加log 更新历史记录
  78. foreach ($oldList as $data) {
  79. $respond['message'] = update_historay($data["id"], $_COOKIE["userid"], $data["text"], $_landmark);
  80. if ($respond['message'] !== "") {
  81. $respond['status'] = 1;
  82. echo json_encode($respond, JSON_UNESCAPED_UNICODE);
  83. exit;
  84. }
  85. }
  86. $respond['status'] = 0;
  87. $respond['message'] = "成功";
  88. foreach ($oldList as $key => $value) {
  89. $update_list[] = array("id" => $value["id"], "book" => $value["book"], "paragraph" => $value["paragraph"], "begin" => $value["begin"], "end" => $value["end"], "channal" => $value["channal"], "text" => $value["text"]);
  90. }
  91. }
  92. }
  93. /* 插入新数据 */
  94. //查询channel语言
  95. if (count($newList) > 0) {
  96. add_edit_event(_SENT_NEW_, "{$newList[0]["book"]}-{$newList[0]["paragraph"]}-{$newList[0]["begin"]}-{$newList[0]["end"]}@{$newList[0]["channal"]}");
  97. $PDO->beginTransaction();
  98. $query = "INSERT INTO "._TABLE_SENTENCE_." (
  99. id,
  100. uid,
  101. parent_uid,
  102. book_id,
  103. paragraph,
  104. word_start,
  105. word_end,
  106. channel_uid,
  107. author,
  108. editor_uid,
  109. content,
  110. language,
  111. version,
  112. status,
  113. strlen,
  114. modify_time,
  115. create_time
  116. )
  117. VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,? )";
  118. $sth = $PDO->prepare($query);
  119. $channel_info = new Channal();
  120. foreach ($newList as $data) {
  121. $uuid = UUID::v4();
  122. if (isset($data["parent"])) {
  123. $parent = $data["parent"];
  124. } else {
  125. $parent = "";
  126. }
  127. $queryChannel = $channel_info->getChannal($data["channal"]);
  128. if ($queryChannel == false) {
  129. $lang = $data["language"];
  130. $status = 10;
  131. } else {
  132. $lang = $queryChannel["lang"];
  133. $status = $queryChannel["status"];
  134. }
  135. $sth->execute(array(
  136. $snowflake->id(),
  137. $uuid,
  138. $parent,
  139. $data["book"],
  140. $data["paragraph"],
  141. $data["begin"],
  142. $data["end"],
  143. $data["channal"],
  144. $data["author"],
  145. $_COOKIE["userid"],
  146. $data["text"],
  147. $lang,
  148. 1,
  149. $status,
  150. mb_strlen($data["text"], "UTF-8"),
  151. mTime(),
  152. mTime(),
  153. ));
  154. $new_id[] = array($uuid, $data["book"], $data["paragraph"], $data["begin"], $data["end"], $data["channal"], $data["text"]);
  155. }
  156. $PDO->commit();
  157. if (!$sth || ($sth && $sth->errorCode() != 0)) {
  158. /* 识别错误且回滚更改 */
  159. $PDO->rollBack();
  160. $error = PDO_ErrorInfo();
  161. $respond['insert_error'] = $error[2];
  162. $respond['new_list'] = array();
  163. } else {
  164. $respond['insert_error'] = 0;
  165. foreach ($new_id as $key => $value) {
  166. $update_list[] = array("id" => $value[0], "book" => $value[1], "paragraph" => $value[2], "begin" => $value[3], "end" => $value[4], "channal" => $value[5], "text" => $value[6]);
  167. }
  168. }
  169. }
  170. $respond['update'] = $update_list;
  171. echo json_encode($respond, JSON_UNESCAPED_UNICODE);
  172. PrefLog();