update.php 3.9 KB

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