2011-07-16 4 views
1

В настоящее время я пытаюсь написать сценарий для переноса базы данных из запатентованной системы CMS в базу данных Joomla 1.6.
Мой код выдает ошибку при последнем «умирании». (К сожалению, я учил сам PHP по пути, я знаю, что я не использую правильную терминологию для всего.)Перенос запатентованной базы данных CMS в базу данных Joomla

<?php 
$username="root"; 
$password=""; 
$database="DATABASE"; 

mysql_connect(localhost,$username,$password); 
@mysql_select_db($database) or die("Unable to select database"); 
$query="SELECT * FROM post3"; 
$result=mysql_query($query); 

$num=mysql_num_rows($result); 

mysql_close(); 

$i=0; 
while ($i < $num) { 

$postid=mysql_result($result,$i,"postid"); 
echo "$postid <br/>"; 

$poster=mysql_result($result,$i,"poster"); 
echo "$poster <br/>"; 

$department=mysql_result($result,$i,"department"); 

if($department=="LIFE"){ 
$department="12";} 
elseif ($department=="NEWS"){ 
    $department="11";} 
    elseif ($department=="SPORTS"){ 
     $department="13";} 
     echo "$department <br/>"; 

$milestone=mysql_result($result,$i,"milestone"); 
echo "$milestone <br/>"; 

$date= date('Y-m-d H:i:s', $milestone); 
echo "$date <br/>"; 

$title=mysql_result($result,$i,"title"); 
echo "$title <br/>"; 

$preview=mysql_result($result,$i,"preview"); 
if (empty($preview)) { 
    $preview=$title; 
} 
echo "$preview<br/>"; 

$alias=str_replace(" ","-", $title); 
echo "$alias <br/>"; 

$bodytext=mysql_result($result,$i,"body_text"); 
echo "$bodytext <br/>"; 

$edited=mysql_result($result,$i,"edited"); 
echo "$edited <br/>"; 

$pop=mysql_result($result,$i,"pop"); 
echo "$pop <br/>"; 

echo "$i Records Copied<br/>"; 


$con = mysql_connect("localhost","root",""); 
if (!$con) 
    { 
    die('Could not connect: ' . mysql_error()); 
    } 

mysql_select_db("DATABASE", $con); 

$sql="INSERT INTO conversion (id, title, alias, introtext, fulltext, state, sectionid, mask, catid, created, created_by, modified, modified_by, checked_out, checked_out_time, publish_up, publish_down, version, parentid, ordering, access, hits, featured, language) 
VALUES 
('$postid','$title','$alias','$preview','$bodytext','1','0','0','$department','$date','$poster','$date','$poster','0','0000-00-00 00:00:00','0000-00-00 00:00:00','0000-00-00 00:00:00','$edited','0','$i','1','$pop','0','*')"; 

if (!mysql_query($sql,$con)) 
    { 
    die ("Query failed: " . mysql_error() . " Actual query: " . $sql); 

    } 
echo "Success <br/>"; 

mysql_close($con); 

$i++; 
} 

?> 

Он вторит все из нормально, но выдает эту ошибку: Сбой запроса: Вы ошибка в синтаксисе SQL; проверьте руководство, соответствующее версии вашего сервера MySQL, для правильного синтаксиса для использования рядом с «полным текстом, состоянием, секцией, маской, catid, created, created_by, измененным, измененным» по строке 1

Любые идеи? Спасибо!

ответ

1

fulltext - зарезервированное ключевое слово MySQL. Если вы хотите использовать его в качестве имени столбца, вам необходимо использовать обратные такты, как в:

`fulltext` 
+0

Ты мой герой. После запоминания добавок и mysql_real_escape_string, где это необходимо, он работает отлично. – Dennis

+0

Я пытался проголосовать за вас, но это мой первый пост, извините. – Dennis

1

«полный текст» - это MySQL reserved word, поэтому либо заключите его в обратные ссылки (например, `fulltext`), либо используйте другое имя для этого поля.

Смежные вопросы