לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #1  
ישן 21-09-2008, 13:08
  טל שמאי טל שמאי אינו מחובר  
 
חבר מתאריך: 26.08.03
הודעות: 46
מנוע חיפוש - אי אפשר לחפש בעברית

שלום לכולם וצהריים טובים.

לפני מס' חודשים עברתי לשרת חדש, ומאז התעוררה בעיה במנוע החיפוש - המערכת לא מציגה תוצאות כאשר מחפשים מילים בעברית. יש לציין שכאשר מחפשים מילים באנגלית, המערכת כן מציגה תוצאות.
מה עשויה להיות הבעיה?

מצ"ב הקוד:

קוד PHP:
<?php
require ("dbc.php");
function 
showLine($words$text){
$lines = Array();
for (
$i=0$i<count($words); $i++){
$pattern "/(\S+\s?){0,5}".$words[$i]."(\S+\s?){0,5}/";
//preg_match_all($pattern, $text, $out, PREG_PATTERN_ORDER);
preg_match($pattern$text$outPREG_OFFSET_CAPTURE);
if (isset(
$out[0][0])){
$lines[] = $out[0][0];
}
}
return 
$lines;
}
function 
boldWords($words$text){
for (
$i=0$i<count($words); $i++){
$text str_replace($words[$i], '<font color="red"><b>'.$words[$i].'</b></font>'$text);
}
return 
$text;
}
if (isset(
$_GET['q'])){
$keysB $_GET['q'];
$q $_GET['q'];
//if (get_magic_quotes_gpc()){
$q stripslashes ($q);
$keysB stripslashes ($keysB);
//}
$q str_replace("'","\'",$q);
$keys explode(" "$q);
}
if (isset(
$_GET['q']) && $keys[0] != ""){
//if (get_magic_quotes_gpc()){
$_GET['q'] = stripslashes ($_GET['q']);
//}
$_GET['q'] = str_replace("'","\'",$_GET['q']);
$keys explode(" "$_GET['q']);
 
if ((!isset(
$_GET['where']) && isset($_GET['q'])) || @$_GET['where'] == "articles"){
$_GET['where'] = "articles";
$searchQuery "SELECT * FROM `articels` WHERE";
for (
$i=0$i<count($keys); $i++){
$searchQuery .= " `date` LIKE BINARY '%".$keys[$i]."%' OR `title` LIKE BINARY '%".$keys[$i]."%' OR `des` LIKE BINARY '%".$keys[$i]."%' OR `body` LIKE BINARY '%".$keys[$i]."%' OR `auther` LIKE BINARY '%".$keys[$i]."%' OR `picDes` LIKE BINARY '%".$keys[$i]."%'";
if ((
$i+1) < count($keys)){
    
$searchQuery .= " OR";
}
}
$searchQuery .= " ORDER BY `id` DESC";
} else if (@
$_GET['where'] == "news"){
$searchQuery "SELECT * FROM `news` WHERE";
for (
$i=0$i<count($searchQuery); $i++){
$searchQuery .= " `date` LIKE BINARY '%".$keys[$i]."%' OR `title` LIKE BINARY '%".$keys[$i]."%' OR `body` LIKE BINARY '%".$keys[$i]."%' OR `auther` LIKE BINARY '%".$keys[$i]."%'";
if ((
$i+1) < count($searchQuery)){
    
$searchQuery .= " OR";
}
}
$searchQuery .= " ORDER BY `id` DESC";
}
}
?>
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #7  
ישן 21-09-2008, 20:52
  משתמש זכר dorM dorM אינו מחובר  
מנהל
 
חבר מתאריך: 26.07.08
הודעות: 6,473
בתגובה להודעה מספר 5 שנכתבה על ידי טל שמאי שמתחילה ב "מדובר באותו קידוד."

הקידוד windows-1255 דומה לקידוד ISO 8859-8 (שזה ב-MySQL הקידוד של hebrew_general_ci, לפי העמוד הבא: http://dev.mysql.com/doc/refman/5.0...t-charsets.html )

לכן מבחינת תאימות הבתים, זה תואם במדויק, לפחות באותיות העיבריות.
האם כאשר אתה מבצע חיפוש, אתה כותב רק אותיות עיבריות, ללא סימנים נוספים? כלומר, מחרוזת החיפוש שלך היא משהו כמו "אבג"?

נסה לבצע את החיפוש ללא ה-BINARY בחלק של "LIKE BINARY". (למרות שזה לא אמור להשפיע, אבל תמיד צריך לנסות.)

מעניין אותי לדעת אם כתבת משהו מיוחד שקשור ל-charset בקובץ dbc.php ?

בכלל, מה שאני הייתי עושה, זה בודק אם המידע שנשלח לשרת ונכנס לשאילתת ה-SQL הוא שווה במדויק (מבחינת הבתים - כמותם והמספר ההקסדצימלי שהם מייצגים) למידע שיש במסד (בתא בטבלה שבו הוא אמור להימצא).
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 10:59

הדף נוצר ב 0.05 שניות עם 12 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2024 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר