update.php 4.4 KB

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