update.php 5.1 KB

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