간단 php 코드, 어디가 문제이죠?

cguy의 이미지

디비에 접속해서 table_$id 의 no=$no 인것을 셀렉트한후 memo 필드를 출력한다.
왜 작동을 안하는걸까요?

소스.php?id=3&no=100 이런식으로 호출합니다.

<?
$conn=mysql_connect("localhost","id","pass");
mysql_select_db("db_name", $conn);

$result=mysql_query("SELECT * FROM table_$id WHERE no=$no");
$data=mysql_fetch_array($result)
echo "$data[memo]";
?>

소타의 이미지

echo "$data[memo]";

하기 직전에

var_dump($data);

이렇게 해서 정말 $data 값이 제대로 넘어 왔는지. 넘어 왔다면 배열로 잘 넘어 왔는지. 필요한 배열의 키가 맞는지 확인해 보세요

kyong의 이미지

cguy wrote:
디비에 접속해서 table_$id 의 no=$no 인것을 셀렉트한후 memo 필드를 출력한다.
왜 작동을 안하는걸까요?

소스.php?id=3&no=100 이런식으로 호출합니다.

<?
$conn=mysql_connect("localhost","id","pass");
mysql_select_db("db_name", $conn);

$result=mysql_query("SELECT * FROM table_$id WHERE no=$no");
$data=mysql_fetch_array($result)
echo "$data[memo]";
?>

에러 메세지를 첨부하세요.
그리고 쓸 데 없이 몇 가지 생각을 보탭니다.
$data = mysql_fetch_array($result);
----------------------------------^
전 $conn 값을 계속 갖고 가길 추천합니다.
* 보다는 분명히 필드를 명시하는 습관을 들이시면 좋습니다.
그리고 query 결과를 검사하는 것이 좋습니다.
if ($result && mysql_num_rows($result)) {
}
else {
}

변수를 포함하지 않을 경우 이중따옴표보다는 단일따옴표가 성능에 좋습니다.
그리고 associative array 는 분명히 다음과 같이 표시해야 합니다.
$data['memo'];
또는 $data["memo"]
전 많은 개발자들이 흔히 저지르는 기본적인 실수라고 생각합니다.

error_reporting(E_ALL);
로 개발하는 습관을 들이면 좋습니다.
그럼 도움이 되셨길......

purewell의 이미지

요즘 PHP는 보안상의 이유로

register_globals의 값이 Off로 되어 있습니다.

따라서 ... src.php?id=10 한다고 해서

$id의 값이 10이 아니라는 소립니다.

ㅡ_-) 그것을 해결하기 위해 김정균님이 맹글어놓은

좋은 소스가 있습니다.

http://kltp.kldp.org/stories.php?story=02/01/20/5891271

PHP의 소스 맨 위에 써놓으면 $id의 값에 원하는 값이 들어가 있을 것입니다.

_____________________________
언제나 맑고픈 샘이가...
http://purewell.biz

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.