Parser_model.php 3.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <?php
  2. defined('BASEPATH') or exit('No direct script access allowed');
  3. /**
  4. *
  5. * Model Parser_model
  6. *
  7. * This Model for ...
  8. *
  9. * @package CodeIgniter
  10. * @category Model
  11. * @author Setiawan Jodi <jodisetiawan@fisip-untirta.ac.id>
  12. * @link https://github.com/setdjod/myci-extension/
  13. * @param ...
  14. * @return ...
  15. *
  16. */
  17. class Parser_model extends CI_Model
  18. {
  19. // ------------------------------------------------------------------------
  20. public function __construct()
  21. {
  22. parent::__construct();
  23. $this->db->save_queries = false;
  24. }
  25. public function inicioParser()
  26. {
  27. $data = array(
  28. 'cron_ejecucion' => 1,
  29. "fecha_ejecucion" => date("Y-m-d h:i:s"),
  30. );
  31. $this->db->where('id', 0);
  32. $this->db->update('parametros_cron', $data);
  33. }
  34. public function stopParser()
  35. {
  36. $data = array(
  37. 'cron_ejecucion' => 0,
  38. "fecha_ejecucion" => date("Y-m-d h:i:s"),
  39. );
  40. $this->db->where('id', 0);
  41. $this->db->update('parametros_cron', $data);
  42. }
  43. public function existCronRun()
  44. {
  45. $sql = "SELECT * FROM parametros_cron";
  46. $result = $this->db->query($sql);
  47. $datos['datos'] = $result->row();
  48. $datos['num_rows'] = $result->num_rows();
  49. $result->free_result();
  50. return $datos;
  51. }
  52. public function getUrlArchivos()
  53. {
  54. $sql = "SELECT * FROM tipo_licitacion_tablas";
  55. $result = $this->db->query($sql);
  56. $datos['datos'] = $result->result();
  57. $datos['num_rows'] = $result->num_rows();
  58. $result->free_result();
  59. return $datos;
  60. }
  61. public function setInicioLicitacion($licitacionArr)
  62. {
  63. $this->db->insert('bruto_datos_iniciales', $licitacionArr);
  64. return $this->db->insert_id();
  65. }
  66. public function getMapaTablas()
  67. {
  68. $sql = "SELECT * FROM mapa_tablas_parser ORDER BY orden ASC";
  69. $result = $this->db->query($sql);
  70. $datos['datos'] = $result->result();
  71. $datos['num_rows'] = $result->num_rows();
  72. $result->free_result();
  73. return $datos;
  74. }
  75. public function truncateTables($tabla)
  76. {
  77. $this->db->truncate($tabla);
  78. }
  79. public function getDatosBrutos($tabla)
  80. {
  81. $sql = "SELECT * FROM $tabla";
  82. $result = $this->db->query($sql);
  83. $datos['datos'] = $result->result();
  84. $datos['num_rows'] = $result->num_rows();
  85. $result->free_result();
  86. return $datos;
  87. }
  88. public function getLicitacionesNuevasBruto()
  89. {
  90. $sql = "SELECT DISTINCT id_licitacion FROM bruto_datos_iniciales";
  91. $result = $this->db->query($sql);
  92. $datos['datos'] = $result->result();
  93. $datos['num_rows'] = $result->num_rows();
  94. $result->free_result();
  95. return $datos;
  96. }
  97. public function deleteCascadaNuevasLicitaciones()
  98. {
  99. $sql = "DELETE
  100. FROM maestro_datos_iniciales_licitacion
  101. WHERE id_licitacion IN(
  102. SELECT DISTINCT id_licitacion FROM bruto_datos_iniciales
  103. )";
  104. $result = $this->db->query($sql);
  105. $datos['num_rows'] = $this->db->affected_rows();
  106. return $datos;
  107. }
  108. public function getMapaByTabla($tabla)
  109. {
  110. $sql = "SELECT * FROM $tabla";
  111. $result = $this->db->query($sql);
  112. $datos['datos'] = $result->result();
  113. $datos['num_rows'] = $result->num_rows();
  114. $result->free_result();
  115. return $datos;
  116. }
  117. }
  118. /* End of file Parser_model.php */
  119. /* Location: ./application/models/Parser_model.php */