save.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. <?php
  2. include "../path.php";
  3. include "../public/_pdo.php";
  4. if(isset($_POST['dict_id'])){
  5. $dict_id=$_POST['dict_id'];
  6. }
  7. else{
  8. $dict_id=-1;
  9. }
  10. if(isset($_POST['word_id'])){
  11. $word_id=$_POST['word_id'];
  12. }
  13. else{
  14. $word_id=-1;
  15. }
  16. if(isset($_POST['data'])){
  17. $data=$_POST['data'];
  18. }
  19. else{
  20. $data="";
  21. }
  22. if(isset($_POST['word_status'])){
  23. $status=$_POST['word_status'];
  24. }
  25. else{
  26. $status="1";
  27. }
  28. $dictFileName=_FILE_DB_REF_;
  29. PDO_Connect("sqlite:$dictFileName");
  30. $query = "update dict set status='$status' where id='$word_id'";
  31. $stmt = @PDO_Execute($query);
  32. if (!$stmt || ($stmt && $stmt->errorCode() != 0)) {
  33. $error = PDO_ErrorInfo();
  34. print_r($error[2]);
  35. }
  36. $dictFileName=$dir_dict_3rd."all.db3";
  37. PDO_Connect("sqlite:$dictFileName");
  38. $query = "DELETE FROM dict WHERE \"from\" = '$word_id' ";
  39. $stmt = @PDO_Execute($query);
  40. if (!$stmt || ($stmt && $stmt->errorCode() != 0)) {
  41. $error = PDO_ErrorInfo();
  42. print_r($error[2]);
  43. }
  44. else{
  45. }
  46. $word_data=json_decode($data);
  47. //print_r($word_data);
  48. //echo "pali:".$word_data[0]->pali."<br>";
  49. // 开始一个事务,关闭自动提交
  50. $PDO->beginTransaction();
  51. $query="INSERT INTO dict ('id','pali','type','gramma','parent','mean','note','factors','factormean','dict_id','from')
  52. VALUES (NULL,?,?,?,?,?,?,?,?,?,?)";
  53. $stmt = $PDO->prepare($query);
  54. foreach($word_data as $value){
  55. $newData=array($value->pali,
  56. $value->type,
  57. $value->gramma,
  58. $value->parent,
  59. $value->mean,
  60. $value->note,
  61. $value->factor,
  62. $value->factor_mean,
  63. $dict_id,
  64. $word_id);
  65. $stmt->execute($newData);
  66. }
  67. // 提交更改
  68. $PDO->commit();
  69. if (!$stmt || ($stmt && $stmt->errorCode() != 0)) {
  70. $error = PDO_ErrorInfo();
  71. echo "error - $error[2] <br>";
  72. }
  73. else{
  74. echo "成功提交".count($word_data)."条数据。";
  75. }
  76. ?>