Bonsoir tout le monde,

Dans le manuel de MySql il est écrit noir sur blanc que la recherche FULLTEXT n'est pas sensible à la casse. Pourtant, mes tests me montrent l'inverse. Ma base est en UTF8-bin et mon système est un dérivé UNIX (Mac OS Leopard), ça peut venir de là ?

Au cas où ce soit utile, voici la façon dont je fais ma recherche, c'est un peu compliqué mais c'est parce que je dois générer ma requête à partir d'un formulaire dont on ne remplit pas forcément tous les champs. Bref, y'a de la concaténation à tout va...

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
<?php
function DisplayNews() {
	if (!empty($_POST['news_search'])) {
		$news = '
			<ul>
		';
		if (!empty($_POST['day'])) {
			$day = "jour = " . $_POST['day'] . "";
			if (!empty($_POST['month']) OR !empty($_POST['year']) OR !empty($_POST['keywords'])) {
				$day.= ' AND ';
			}
		}
		if (!empty($_POST['month'])) {
			$month = "mois = " . $_POST['month'] . "";
			if (!empty($_POST['year']) OR !empty($_POST['keywords'])) {
				$month.= ' AND ';
			}
		}
		if (!empty($_POST['year'])) {
			$year = "annee = " . $_POST['year'] . "";
			if (!empty($_POST['keywords'])) {
				$year.= ' AND ';
			}
		}
		if (!empty($_POST['keywords'])) {
			$keywords = "MATCH (titre,contenu) AGAINST ('" . $_POST['keywords'] . "')";
		}
		$__news = mysql_query("SELECT * FROM news WHERE $day$month$year$keywords") or die (mysql_error());
		while ($_news = mysql_fetch_array($__news)) {
			$news.= '
				<li>' . $_news['contenu'] . '</li>
			';
		}
		$news.= '
			</ul>
		';
		echo $news;
	}
}
?>
Merci d'avance pour votre passage sur ce post

P.S. J'ai bien sûr créé un index sur les colonnes idoines et j'ai réussi à avoir des requêtes qui marchent si je respecte les majuscules.