【问题标题】:Data not inserting into database unless I refresh the page?除非我刷新页面,否则数据不会插入数据库?
【发布时间】:2013-07-17 01:45:45
【问题描述】:

我有以下文件,他们就是这样做的:

input.php: 从 XML 提要中获取数据,连接到数据库并将其输入到数据库中。
output.php: 连接到数据库并创建要输出的变量。
index.php: 包含output.php 并使用变量输出数据。
refresh.js: Ajax 刷新 div 以更新数据。


输入.php

$xml = simplexml_load_file( "http://domain.com/feed" );
$json = json_encode( $xml );
$array = json_decode( $json,TRUE );
$items = $array['channel']['item'];

$DB = new mysqli( 'localhost','USERNAME','PASSWORD','DATABASE' );
if( $DB->connect_errno ){
  print "failed to connect to DB: {$DB->connect_error}";
  exit( 1 );
}

$match = "#^(?:[^\?]*\?url=)(https?://)(?:m(?:obile)?\.)?(.*)$#ui";
$replace = '$1$2';

foreach( $items as $item ){
  $title = $item['title'];
  $url = preg_replace( $match,$replace,$item['link'] );
  $title_url[] = array( $title,$url );
  $sql_values[] = "('{$DB->real_escape_string( $title )}','{$DB->real_escape_string( $url )}')";
}
$SQL = "INSERT IGNORE INTO `read`(`title`,`url`) VALUES\n ".implode( "\n,",array_reverse( $sql_values ) );
if( $DB->query( $SQL ) ){
} else {
  print "failed to INSERT: [{$DB->errno}] {$DB->error}";
}
$DB->set_charset( 'utf8' );

输出.php

$DB = new mysqli( 'localhost','USERNAME','PASSWORD','DATABASE' );
if( $DB->connect_errno ){
  print "failed to connect to DB: {$DB->connect_error}";
  exit( 1 );
}

$query = "SELECT `title`,`url` FROM `read` ORDER BY `order` DESC";
$result = $DB->query( $query );
// error-handling: make sure query returned a result
if( $result ){
  while( $row = $result->fetch_array() ){
      // list gets values from a numeric array
      list( $title,$url ) = $row;
      // using [] (append) is much faster than using array_push()
      $data[] = array( 'title'=>$title,'url'=>$url );
}
$title = $data[0]['title'];
$url = $data[0]['url'];
}else{
  //do something
}

索引.php

<!doctype html>
<html>
<head>
  <meta charset="utf-8">
  <title>Recently</title>
  <script src="//ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
  <script src="js/refresh.js"></script>
</head>

<body>
  <?php include_once "includes/output.php"; ?>

  <p class="title"><span>Read </span>
    <a  id="read" href="<?php echo $url; ?>" target="_blank"><?php echo $title; ?></a>  
  </p>

</body>
</html>

刷新.js

var auto_refresh = setInterval(
 function() {
   $('#read').load('index.php #read');
 }, 2000);

问题是除非我刷新input.php(这会搞砸增量计数),否则数据不会插入到数据库中。我不知道为什么会这样。有什么想法吗?

注意:因为我刚刚开始了解有关 PHP 和数据库的更多信息,所以我希望我的 input.phpoutput.php 代码在需要时进行最低限度的更改 em>。

【问题讨论】:

  • 希望我能很好地解释我的问题。如有必要,我愿意进一步解释。

标签: php mysql ajax database


【解决方案1】:

基本上你当前的工作流程是:执行input.php一次=>使用JS在一个区间内执行output.php得到输出。所以你可以看到问题是输入有点静态而输出是动态的。

您可以单独修改您的刷新脚本:执行input.php => 执行output.php => 几秒钟后再次执行input.php => 再次执行output.php 等等:

var auto_refresh = setInterval(function() {
    $.get('input.php', function () { // call input here
        $('#read').load('index.php #read'); // call output here
    });    
}, 2000); // run again after 2 seconds, you might wanna make this number higher to offload i/o

希望这会有所帮助。

【讨论】:

  • 这很有意义。我现在遇到的唯一问题是增量值在下一次输入数据库时​​发生显着变化。见这里:cloud.chrisburton.me/QMjh。下一个输入 order 值将类似于 1120 而不是 37
  • 这个数字重要吗?无论如何,您可能会在之前插入一个大值,因此当前值就那么大。您始终可以使用以下方法重置自动增量值:ALTER TABLE tablename AUTO_INCREMENT = 37
  • 这不重要,不。只是真的很烦。它发生是因为 AJAX。使用该 SQL 语句,每次将数据插入数据库时​​,我都必须这样做。
  • 不,auto_increment 只能手动重置一次。之后,每次有 INSERT 查询时,它都会增加 1,它的工作方式是:获取该列中的最大值并将该数字增加 1。所以当然你需要删除/修改大的行值 ID,以便下次具有低值。
  • 不幸的是,它不是这样做的。如果我将增量​​重置为下一个插入应该是什么,一切都很好。但是,在这之后的以下插入,增量会大大提高。因此必须不断地编辑值。如果我删除 AJAX 脚本,它就不会这样做。
【解决方案2】:

将您的 input.php 和 output.php 合并到一个文件中(例如 io.php)。

// input.php content
// output.php content
// And instead of creating $title and $url variables use this

header('Content-type: application/json');
echo json_encode($data[0]);

不再需要在 index.php 中包含任何文件,只需编辑您的 refresh.js,如下所示

setInterval(function(){ $.ajax({
  url: 'io.php',
  type: 'GET',
  dataType: 'json',
  cache: false,
  success: function(m){
    $('#read').text(m.title).attr('href',m.url);
  }
}); }, 2000);

而且也不需要重新加载 index.php。我认为这是更有效的方式

编辑:这是完整的代码。

可能还有其他代码块需要在 index.php 中包含 output.php 或与我的方法相冲突的内容。我不知道有关您的系统的此类附加信息。这只是一个建议。

io.php

(input.php + output.php) 我不知道合并这些文件时是否还需要保存在数据库中,但是您可以在另一个页面中使用这些保存的数据。

$xml = simplexml_load_file( "http://domain.com/feed" );
$json = json_encode( $xml );
$array = json_decode( $json,TRUE );
$items = $array['channel']['item'];

$DB = new mysqli( 'localhost','USERNAME','PASSWORD','DATABASE' );
if( $DB->connect_errno ){
  print "failed to connect to DB: {$DB->connect_error}";
  exit( 1 );
}

$match = "#^(?:[^\?]*\?url=)(https?://)(?:m(?:obile)?\.)?(.*)$#ui";
$replace = '$1$2';

foreach( $items as $item ){
  $title = $item['title'];
  $url = preg_replace( $match,$replace,$item['link'] );
  $title_url[] = array( $title,$url );
  $sql_values[] = "('{$DB->real_escape_string( $title )}','{$DB->real_escape_string( $url )}')";
}
$SQL = "INSERT IGNORE INTO `read`(`title`,`url`) VALUES\n ".implode( "\n,",array_reverse( $sql_values ) );
if( $DB->query( $SQL ) ){
} else {
  print "failed to INSERT: [{$DB->errno}] {$DB->error}";
}
$DB->set_charset( 'utf8' );

$query = "SELECT `title`,`url` FROM `read` ORDER BY `order` DESC";
$result = $DB->query( $query );
// error-handling: make sure query returned a result
if( $result ){
  while( $row = $result->fetch_array() ){
      // list gets values from a numeric array
      list( $title,$url ) = $row;
      // using [] (append) is much faster than using array_push()
      $data[] = array( 'title'=>$title,'url'=>$url );
}

header('Content-type: application/json');
echo json_encode($data[0]);

}else{
  //do something
}

index.php

<!doctype html>
<html>
<head>
  <meta charset="utf-8">
  <title>Recently</title>
  <script src="//ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
  <script src="js/refresh.js"></script>
</head>

<body>

  <p class="title"><span>Read </span>
    <a  id="read" href="" target="_blank"></a>  
  </p>

</body>
</html>

刷新.js

setInterval(function(){ $.ajax({
  url: 'io.php',
  type: 'GET',
  dataType: 'json',
  cache: false,
  success: function(m){
    $('#read').text(m.title).attr('href',m.url);
  }
}); }, 2000);

【讨论】:

  • 我没有关注?我应该把 header() 和 echo 放在哪里?
  • 通过结合 input.php 和 output.php 创建 io.php(或其他内容)后,将 header() 和 echo 替换为这些行 $title = $data[0]['title']; $url = $data[0]['url'];
  • 除了我已有的方法还有其他方法吗?虽然上面的代码可能很有效,但很难理解。我对 PHP 和数据库的了解并不是那么好。我拥有的 AJAX 还包含另一个 .load(),用于完全不同的 API。希望保留它。
  • 我编辑了我的答案以显示所有文件。我希望这对你有帮助。
【解决方案3】:

那是因为你打电话给input.php一次

在你的index.php 中没有任何地方你再次调用它,所以output.php 被调用并获取最新行ORDER BY order DESC 然后$url = $data[0]['url']

必须再次致电input.php才能获得新数据。

你可以把你的 refresh.js 改成这样:

(function refresh() {
  $.get('input.php', function() {
    $("#read").load("index.php", function() {
      refresh();
    });
  });
})(); // self-executing anonymous functions are better than setInterval() to handle ajax

【讨论】:

  • 这似乎会吐出额外的内容并大大降低网站速度。
  • 如果你想获得更新的内容,你需要以某种方式刷新input.php,否则你必须遍历MySQL查询......即index.php?i=3和内部output.php你必须$index = $_GET['i'];$query = "SELECT title, url FROM read ORDER BY order DESC LIMIT $index, 1";
  • 所以因为我使用的是include_once,它会导致问题吗?如果我删除include_once 并坚持使用include 会怎样?
  • 另外,虽然这不是非常重要,但这种事情让我很恼火。如何阻止 AJAX 大幅增加增量值?
  • @ChrisBurton,你能看看你的数据库吗,我认为你的 INSERT IGNORE 没有做你想做的事。
【解决方案4】:

也许您的请求正在被缓存。尝试改变:

   $('#read').load('index.php?r='+ Math.floor((Math.random()*100)+1) +' #read');

【讨论】:

  • 不幸的是,这并不能解决问题。它似乎仍然发生=/。我必须刷新input.php 才能使 Ajax 生效。
猜你喜欢
  • 1970-01-01
  • 2012-11-12
  • 2017-02-16
  • 1970-01-01
  • 2012-06-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多