Solved

php sql full text

Posted on 2003-11-05
16
181 Views
Last Modified: 2010-07-27
hi all,,,


This is mySQl query work works no promlem in the DB but not in php ...why


SQL

           SELECT directory. * ,
MATCH (
keywords, title
)
AGAINST (
'%%%pottery%%'
) AS score
FROM directory
WHERE MATCH (
keywords, title
)
AGAINST (
'%%%pottery%%'
)
ORDER BY score DESC


PHP


<?php
 MySQL_connect("xxxxxxxxxxxxxx", "xxxxxxxxxxxx", "xxxxxxxxxxxxx");
    MySQL_select_db("xxxxxxxxxxxxxxxxxx");
        $sql = "
           SELECT directory. * ,
MATCH (
keywords, title
)
AGAINST (
'%%%pottery%%'
) AS score
FROM directory
WHERE MATCH (
keywords, title
)
AGAINST (
'%%%pottery%%'
)
ORDER BY score DESC
        ";
        $res = MySQL_query($sql);
?>


THanks

G
0
Comment
Question by:gabss
  • 6
  • 4
  • 2
  • +1
16 Comments
 
LVL 57

Expert Comment

by:Pete Long
ID: 9686182
Hi ninobennett,
do you have the plugin for exchange?? what do the veritas job logs tell you?? do you have the open file option installed

Cheers!
0
 
LVL 6

Expert Comment

by:DoppyNL
ID: 9686216
run youre query like this and you can see the error wich is occuring:
$res = mysql_query($sql , $connection) or die("<b>Query Failed</b><br>\n".$sql."<br>\n".mysql_errno().": ".mysql_error());
0
 
LVL 1

Author Comment

by:gabss
ID: 9686240
it returns only " Query Error "

nowt else....

any other help ?????????

and Petelong what u on about ?


G
0
 
LVL 6

Expert Comment

by:DoppyNL
ID: 9686286
strange that it returns " Query Error ", as that is not in the code....

try this one:
$res = mysql_query($sql) or die("<b>Query Failed</b><br>\n".$sql."<br>\n".mysql_errno().": ".mysql_error());

if still no result try
print($sql);
to check if the sql is correct in PHP (some string parsing might make the sql incorrect).

you can also try to put your sql on a single line:
$sql = "SELECT directory. * , MATCH (keywords, title) AGAINST ('%%%pottery%%') AS score FROM directory WHERE MATCH (keywords, title ) AGAINST ('%%%pottery%%') ORDER BY score DESC";
0
 
LVL 17

Expert Comment

by:Squeebee
ID: 9690780
You can also drop the % symbols unless you are really searching for a literal % symbol, in which case you should escape it with \%
0
 
LVL 1

Author Comment

by:gabss
ID: 9693659
DoppyNL

Thanks this works BUT:

$sql = "SELECT directory. * , MATCH (keywords, title) AGAINST ('%%%pottery%%') AS score FROM directory WHERE MATCH (keywords, title ) AGAINST ('%%%pottery%%') ORDER BY score DESC";


i have new BIG BIG problem with it....

If one row in db contains the word "pottery" it return it no problem.....

BUT

If 2 rows in db contain the wor "pottery" it return nothing

Any ideas


Thanks

G
0
 
LVL 17

Expert Comment

by:Squeebee
ID: 9693864
Did you try dropping all those % symbols?
0
Top 6 Sources for Identifying Threat Actor TTPs

Understanding your enemy is essential. These six sources will help you identify the most popular threat actor tactics, techniques, and procedures (TTPs).

 
LVL 1

Author Comment

by:gabss
ID: 9693948
yep tried that ???

Same problem ???

im lost...

please help ???

G
0
 
LVL 17

Expert Comment

by:Squeebee
ID: 9693999
How many rows are in the table? I term that appears in too many rows is considered a stop-word and is not searched against, since too large a percentage of rows will be returned.
0
 
LVL 1

Author Comment

by:gabss
ID: 9694029
only 4 ....

i'll add a load now and see

cheers
0
 
LVL 1

Author Comment

by:gabss
ID: 9694064
yeh it sort of works....

BUT

im doing a niche directory so 10 sites might have the same keywords..... out of 20 ....

Is there a work around ?


Thanks again

G

0
 
LVL 1

Author Comment

by:gabss
ID: 9694088
it only work with 4 lettered words ?

can it do 3 ??

thanks again

G
0
 
LVL 17

Accepted Solution

by:
Squeebee earned 40 total points
ID: 9694529
Three letter words are too short, it is possible to change the setting and recompile if needs be, you can also use the IN BOOLEAN MODE searching to get around the half row limits and 3 word constraints.
0
 
LVL 57

Expert Comment

by:Pete Long
ID: 11145088
Hello this question has been open a while please take the time to come back and clean it up.

Closing Questions
http://www.experts-exchange.com/help.jsp#hs5


Best Wishes

Pete
www.petenetlive.com
0

Featured Post

Highfive + Dolby Voice = No More Audio Complaints!

Poor audio quality is one of the top reasons people don’t use video conferencing. Get the crispest, clearest audio powered by Dolby Voice in every meeting. Highfive and Dolby Voice deliver the best video conferencing and audio experience for every meeting and every room.

Join & Write a Comment

Suggested Solutions

Title # Comments Views Activity
scandir() not reads all files 4 26
PHP connection to remote AWS MySQL RDS 4 38
wordpress issue 2 20
PHP json decode 9 0
Things That Drive Us Nuts Have you noticed the use of the reCaptcha feature at EE and other web sites?  It wants you to read and retype something that looks like this.Insanity!  It's not EE's fault - that's just the way reCaptcha works.  But it is …
Password hashing is better than message digests or encryption, and you should be using it instead of message digests or encryption.  Find out why and how in this article, which supplements the original article on PHP Client Registration, Login, Logo…
This tutorial will teach you the core code needed to finalize the addition of a watermark to your image. The viewer will use a small PHP class to learn and create a watermark.
The viewer will learn how to create a basic form using some HTML5 and PHP for later processing. Set up your basic HTML file. Open your form tag and set the method and action attributes.: (CODE) Set up your first few inputs one for the name and …

705 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

14 Experts available now in Live!

Get 1:1 Help Now