除非刷新页面,否则数据不会插入数据库中?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了除非刷新页面,否则数据不会插入数据库中?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2963字,纯文字阅读大概需要5分钟。
内容图文
我有以下文件,这是它们的作用:
input.php:从XML提要中获取数据,连接到数据库并将其输入数据库.
output.php:连接到数据库并创建要输出的变量.
index.php:包括output.php并使用变量输出数据.
refresh.js:Ajax刷新div以更新数据.
Input.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' );
Output.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
}
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>
<?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>
Refresh.js
var auto_refresh = setInterval(
function() {
$('#read').load('index.php #read');
}, 2000);
问题在于,除非我刷新input.php(这会增加增量计数),否则数据不会插入数据库中.我不知道为什么会这样.有什么想法吗?
注意:因为我才刚刚开始学习有关PHP和数据库的更多信息,所以我希望在需要时对我的input.php和output.php代码进行最小程度的更改.
解决方法:
基本上,您当前的工作流程是:执行一次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
希望这可以帮助.
内容总结
以上是互联网集市为您收集整理的除非刷新页面,否则数据不会插入数据库中?全部内容,希望文章能够帮你解决除非刷新页面,否则数据不会插入数据库中?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。