会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132904个问题

老师我在添加文章时页面提示添加失败报错主键id不能为0,但查看数据库时发现添加了一条id=0的数据,是什么原因

news.php

<?php
    try{
        $con=new PDO("mysql:host=localhost;dbname=newsdb;charset=utf8","root","");
        $con->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
        $res=$con->query("select * from news");
        $data=$res->fetchAll(PDO::FETCH_ASSOC);
//      字符串拼接
 $str='';
        for($i=0;$i<count($data);$i++){
            $str.="<tr><td>{$data[$i]['id']}</td><td>{$data[$i]['title']}</td><td>{$data[$i]['author']}</td><td>{$data[$i]['des']}</td><td>{$data[$i]['content']}</td><td>{$data[$i]['time']}</td><td><a href='#'>删除</a><a href='#'>修改</a></td></tr>";
        }

    }catch(PDOException $e){
        echo $e->getMessage();
    }
?>
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
 content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <div class="container">
        <div class="left">
            <a href="javascript:;">所有文档列表</a>
            <a href="addnews.html">添加文档</a>
        </div>
        <div class="right">
            <table border="1" cellpadding="0" cellspacing="0" width="100%">
                <tr>
                    <th>ID</th>
                    <th>标题</th>
                    <th>作者</th>
                    <th>描述</th>
                    <th width="40%">内容</th>
                    <th>时间</th>
                    <th>操作</th>
                </tr>
                <?php
                    echo $str;
                ?>
            </table>
        </div>
    </div>
</body>

addnews.html

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
 content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .container {width: 500px;margin: 100px auto;overflow: hidden;}
        .left,.right {float: left;}
        .left {width: 150px;}
        .right {width: 350px;}
        textarea {vertical-align: top;}
        button {display: block;width: 100px;height: 40px;margin: 10px auto;cursor: pointer;}
    </style>
</head>
<body>
    <div class="container">
        <div class="left">
            <a href="#">添加文档页面</a>
        </div>
        <div class="right">
            <form action="addnews.php" method="get">
                标题:<input type="text" name="title"><br/>
                作者:<input type="text" name="author"><br/>
                描述:<input type="text" name="des"><br/>
                内容:<textarea name="content" id="" cols="30" rows="10"></textarea>
                <button>提交</button>
            </form>
        </div>
    </div>
</body>
</html>

addnews.php

<?php
//    接收用户传来的数据
//    isset()判断传值是否为空
    $title=isset($_GET['title'])?$_GET['title']:'';
    $author=isset($_GET['author'])?$_GET['author']:'';
    $des=isset($_GET['des'])?$_GET['des']:'';
    $content=isset($_GET['content'])?$_GET['content']:'';
//    生成一个时间
    $time = time();
//    写入数据库
    $con=new PDO("mysql:host=localhost;dbname=newsdb;charset=utf8","root","");
    $con->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
    $res=$con->query("insert into news (title,author,des,content,time) values ('{$title}','{$author}','{$des}','{$content}','{$time}')");
    if($res){
        echo "<script>alert('添加成功');window.location href='news.php'</script>";
    }else {
        print_r($con);
        echo "添加失败";
    }
?>

数据库设计

image.png

运行结果

image.png

image.png

WEB前端全系列/第五阶段:前后端交互/PHP、数据库编程与设计 20731楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/数据结构 20733楼
JAVA 全系列/第五阶段:JavaWeb开发/Ajax技术详解(旧) 20735楼
JAVA 全系列/第九阶段:权限控制与安全认证/Spring Security(旧) 20736楼
JAVA 全系列/第一阶段:JAVA 快速入门/控制语句、方法、递归算法 20737楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 20738楼
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/FastDFS 20739楼

老师在讲不同步的情况下Chrome浏览器先刷新,IE浏览器后刷新,IE浏览器能输出结果,

我在这里说一下我的理解

            首先:chrome浏览器和IE浏览器发送的是两个不同的请求,因此,他们的request对象,和response对象是不同的

                    那么你谷歌浏览器先请求,然后休眠了,因为是多线程,并且是用成员变量作为输出流的载体,那么过程是这样,        谷歌浏览器请求: pw=谷歌的response  → 谷歌线程休眠 → IE线程开始 pw=IE的response  

                                        → 谷歌线程唤醒,往下执行 → 谷歌线程拿着已经被覆盖的pw(IE的响应字符输出流)                                            做输出,这就导致了,谷歌页面是空白,并且IE浏览器不仅没有在5秒休眠结束才显示,                                            而是在谷歌浏览器的响应代码执行完毕就显示了。

                            所以:这和老师解释是不同的,老师说,是因为close方法执行了,导致拿不到pw对象,

                            我觉得这说法不对误导同学了。为此回去重新学习了一轮多线程

                                                         你看我这理解对还是老师的说法对?

JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解(旧) 20741楼
JAVA 全系列/第二十一阶段:分布式医疗云平台/项目环境搭建(旧) 20742楼
人工智能/第二十三阶段:Pytorch项目实战/PyTorch编码器解码器_机器翻译 20745楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637