新手问题 - php中,$_GET中的数值能被mySQL读到么?
<?php include("../conn.php"); if ($_GET[post]) { $sql = "SELECT * FROM message WHERE id = $_GET[post]"; $query = mysql_query($sql); $row = mysql_fetch_array($query); } if($_POST['submit']) { $sql = "insert into reply (id,id_p,time,content) values('','$_GET[post]',now(),'$_POST[content]')"; mysql_query($sql); echo "<meta http-equiv=refresh content=0"; } ?>
在
$sql = "insert into reply (id,id_p,time,content) values('','$_GET[post]',now(),'$_POST[content]')";
中,id_p的值一直是0,其余的取值都正常,不知道为什么
.$_GET[post]是有值的,在这段代码上方和下方都能用,但是就在这个SQL语句当中不能用...
想了很多办法,比如在代码前面加上$a = $_GET[post],用$row[id](message表中的id其实就是$_GET[post]的值),都不读不到取值;
难道是
echo "
的问题?![]()
回复内容:
<?php include("../conn.php"); if ($_GET[post]) { $sql = "SELECT * FROM message WHERE id = $_GET[post]"; $query = mysql_query($sql); $row = mysql_fetch_array($query); } if($_POST['submit']) { $sql = "insert into reply (id,id_p,time,content) values('','$_GET[post]',now(),'$_POST[content]')"; mysql_query($sql); echo "<meta http-equiv=refresh content=0"; } ?>로그인 후 복사在
$sql = "insert into reply (id,id_p,time,content) values('','$_GET[post]',now(),'$_POST[content]')";로그인 후 복사로그인 후 복사
中,id_p的值一直是0,其余的取值都正常,不知道为什么
.$_GET[post]是有值的,在这段代码上方和下方都能用,但是就在这个SQL语句当中不能用...想了很多办法,比如在代码前面加上$a = $_GET[post],用$row[id](message表中的id其实就是$_GET[post]的值),都不读不到取值;
难道是
echo "<meta http-equiv="refresh" content='0";</pre'> <br> 的问题?<br><img src="/static/imghw/default1.png" data-src="http://segmentfault.com/img/bEGSH7" class="lazy" data- alt="新手问题 - php中,$_GET中的数值能被mySQL读到么?" > <p class="answer fmt" data-id="1020000000097100"> </p><p>我觉得你最好定义一个变量给GET过来的值,因为我以前有试过,貌似在SQL语句里头赤果果的写$_GET这样的是行不通的,个人愚见。<br> PS:里头代码低级错误貌似好多额...建议改改在测试...</p> <p class="answer fmt" data-id="1020000000097097"> </p><p>把sql中的<code>$_GET[post]</code>改成<code>{$_GET['post']}</code></p><p>另外,你得加强下编码习惯的培养,这段代码的缩进让人看着抓狂,还有这句<code>echo "<meta http-equiv="refresh" content='0";</code'>输出的html居然没有用<code>></code>闭合,属性也没有用双引号。。。需要修炼下程序员的气质</code></p> <p class="answer fmt" data-id="1020000000097099"> </p><p>首先,你要搞清楚,mysql不会执行任何页面提交过来的任何值;<br> 其次,按你贴的代码的意思,php会解析你页提交过来的值,生成sql 语句;<br> 再次,你的代码书写的令人相当难受,乱缩进,毫无层次感;<br> 再次,请确定你的页面的提交方式,到底是 GET,还是 POST,如果不确定,请直接用 REQUEST,一会 GET,一会 POST ,真是别扭啊;<br> 最后,请你在<code>""</code>里面写复杂变量时,记得加上{},如<code>{$POST['post']}</code></p><p>补充:<br> 确认一下你页面提交过来的参数是否是<code>post</code><br> 你可以在贴出的这个代码的页面打印出页面提交过来的所有值,在开头部份添加以下代码:<br><code>echo <xmp>;</xmp></code><br><code>var_dump($_REQUEST);</code><br><code>echo ;</code></p> <p class="answer fmt" data-id="1020000000097105"> </p><p>你的字段用了tinyint,tinyint是从-128~127的,会不会溢出了?<br> 还有,其实本质上int(10)和int(1)没区别,所以一般不是那种true or false或者是status类型的字段,都不用int(1),你给一个int(10)就好了。</p><p>执行这个把表结构改一下</p><pre class="brush:php;toolbar:false">$sql = "alter table reply change id id int(10) NOT NULL AUTO_INCREMENT"; mysql_query($sql) or die(mysql_error()); $sql = "alter table reply change id_p id_p int(10) NOT NULL"; mysql_query($sql) or die(mysql_error());로그인 후 복사然后把代码改成这样,把所有信息都打出来看看。
if($_POST['submit']) { $sql = "insert into reply (id_p,time,content) values('{$_GET['post']}',now(),'{$_POST['content']}')"; echo $sql; mysql_query($sql) or die(mysql_error()); $sql = "select * from reply order by id DESC limit 1"; $query = mysql_query($sql); $result = mysql_fetch_array($query); var_dump($result); // echo "<meta http-equiv="refresh" content="0">"; }로그인 후 복사sql的问题有这么几个:
- 既然id已经是自增主键了,那么就不用在sql里显式插入了
- 双引号里的变量最好用{}括起来
- mysql_query要做错误处理,比如 or die(mysql_error()) 这种用法

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.
