你有沒有想過如何使用搜索功能在所有整站中實現(xiàn)!互聯(lián)網(wǎng)博客和網(wǎng)站,大多數(shù)都采用MySQL數(shù)據(jù)庫。MySQL提供了一個美妙的方式實施一個小的搜索引擎,在您的網(wǎng)站(全文檢索)。所有您需要做的是擁有的MySQL 4.x及以上。MySQL提供全文檢索功能,我們可以用它來 ??實現(xiàn)搜索功能。
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設,碭山企業(yè)網(wǎng)站建設,碭山品牌網(wǎng)站建設,網(wǎng)站定制,碭山網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,碭山網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
首先,讓我們?yōu)槲覀兊睦又性O置一個示例表。我們將創(chuàng)建一個名為第一個表。
CREATE TABLE articles (
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
title VARCHAR(200),
body TEXT,
FULLTEXT (title,body)
);
在此表中還可以添加一些示例數(shù)據(jù)。執(zhí)行后,插入查詢。
INSERT INTO articles (title,body) VALUES
('MySQL Tutorial','DBMS stands for DataBase ...'),
('How To Use MySQL Well','After you went through a ...'),
('Optimizing MySQL','In this tutorial we will show ...'),
('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
('MySQL vs. YourSQL','In the following database comparison ...'),
('MySQL Security','When configured properly, MySQL ...');
一旦樣本數(shù)據(jù)是準備好,我們可以開始我們的全文檢索功能。
自然語言全文搜索
嘗試我們的示例表上執(zhí)行下面的SELECT查詢。
SELECT * FROM articles
WHERE MATCH (title,body) AGAINST ('database');
你就能看到結果如下:
在下面的數(shù)據(jù)庫比較5 MySQL與YourSQL的...
MySQL教程DBMS 1代表數(shù)據(jù)庫...
我們在上面的SQL查詢(標題,正文)反對(“數(shù)據(jù)庫”)的比賽,選擇所有的記錄,列標題和正文進行全文搜索。
您可以修改該查詢,并創(chuàng)建您自己的版本,以自己的數(shù)據(jù)庫中執(zhí)行全文搜索。
布爾全文搜索
它可能發(fā)生,你要指定某些關鍵字在您的搜索條件。此外,您可能要忽略某些關鍵字。布爾全文搜索可以用來執(zhí)行這些要求的全文檢索。
檢查下面的SELECT查詢。
SELECT * FROM articles WHERE MATCH (title,body)
AGAINST ('+MySQL -YourSQL' IN BOOLEAN MODE);
如果您發(fā)現(xiàn)上述選擇查詢,我們增加了布爾MODE反對()。這個查詢將獲取MySQL的關鍵字,但不YourSQL關鍵字的所有記錄。請注意+和-我們以前指定的關鍵字!
在執(zhí)行此功能,MySQL使用什么有時也被稱為布爾邏輯作為暗示,其中:+代表與-代表不是[無操作員]暗示或
以下是幾個例子布爾搜索條件。
“蘋果香蕉
查找行至少包含兩個詞之一。
“+蘋果+果汁”
尋找包含兩個單詞的行。
“+蘋果Macintosh
查找行包含“蘋果”,但排名的行,如果它們也包含“麥金塔”。
“+蘋果Macintosh的”
查找行包含“蘋果”這個詞,而不是“麥金塔”。
'+蘋果Macintosh的“
查找包含單詞“蘋果”的行,但如果該行也包含單詞“麥金塔”,速度比如果行不低。這是“軟”比“+蘋果Macintosh電腦”,為“麥金塔”的存在,導致該行不能在所有返回的搜索。
'+蘋果+(營業(yè)額餡餅)“
行包含“蘋果”和“營業(yè)額”,或“蘋果”和“餡餅”(任何順序)的話,但排名“蘋果的營業(yè)額”比“蘋果餡餅“。
限制
支持全文檢索的MyISAM表只。MySQL 4.1中,使用多個字符設置一個單一的表內的支持。然而,在一個FULLTEXT索引的所有列,必須使用相同的字符集和校對規(guī)則。MATCH()列列表必須匹配完全在一些列清單表的FULLTEXT索引定義,除非這場比賽()是在布爾模式。布爾模式搜索,可以做非索引列,雖然他們很可能是緩慢的。
辦法如下:
select * from table1 where concat(`字段`,`字段`,`字段` ) like '%關鍵字%' union
select * from table2 where concat(`字段`,`字段`,`字段` ) like '%關鍵字%' union
select * from table3 where concat(`字段`,`字段`,`字段` ) like '%關鍵字%' union
select * from table4 where concat(`字段`,`字段`,`字段` ) like '%關鍵字%' union
select * from table5 where concat(`字段`,`字段`,`字段` ) like '%關鍵字%'?
前提是查詢出來的字段個數(shù)要一樣,類型要對應好,至于如何得到正確且符合你需要的sql就要在程序類中處理了。
在數(shù)據(jù)庫中查找某一字段的值的操作方法和步驟如下:
1、首先,在桌面上,單擊“
Management Studio”圖標,如下圖所示。
2、其次,完成上述步驟后,在該界面中,單擊左上角的“新建查詢”按鈕,如下圖所示。
3、接著,完成上述步驟后,輸入如下紅框標注的SQL語句,如下圖所示。
4、然后,完成上述步驟后,在該界面中,單擊左上方的“執(zhí)行”選項,如下圖所示。
5、最后,完成上述步驟后,在此界面中,顯示查詢數(shù)據(jù)庫有某個字段,如下圖所示。這樣,問題就解決了。
?php
$host_name="localhost"; //服務器名
$host_user="root"; //連接服務器的用戶名
$host_pass="123456"; //連接服務器的密碼
$db_name=""; //服務器上的可用數(shù)據(jù)庫
$my_conn=mysql_connect($host_name,$host_user,$host_pass); //連接服務器
mysql_select_db($db_name,$my_conn); //選擇操作的數(shù)據(jù)庫
mysql_query("SET NAMES utf-s"); //設置編碼
$sql="select content from sheet where id=0 "http://mysql語句
//從sheet表中查詢id=0的content的值
$row = mysql_fetch_array(mysql_query($sql,$my_conn));//從mysql返回的結果中提取一 //行
?
mysql
like
語法
like
運算符用于
where
表達式中,以搜索匹配字段中的指定內容,語法如下:
where
column
like
pattern
where
column
not
like
pattern
在
like
前面加上
not
運算符時,表示與
like
相反的意思,即選擇
column
不包含
pattern
的數(shù)據(jù)記錄。
like
通常與通配符
%
一起使用,%
表示通配
pattern
中未出現(xiàn)的內容。而不加通配符
%
的
like
語法,表示精確匹配,其實際效果等同于
=
等于運算符。
mysql
like
大小寫
mysql
like
匹配字符時,默認是不區(qū)分大小寫的,如果需要在匹配的時候區(qū)分大小寫,可以加入
binary
操作符:
select
*
from
user
where
username
like
binary
'%azz%'select
*
from
user
where
username
like
binary
'%azz%'
binary
操作符表示按照二進制進行比較,因此加上該操作符后,便可以嚴格區(qū)分大小寫,因此以上兩條
sql
查詢出來的內容是不同的。
mysql
like
中文字符匹配
由于數(shù)據(jù)存儲編碼問題,在某些情況下,mysql
進行
like
搜索返回的數(shù)據(jù)中除了符合要求的數(shù)據(jù)外,往往還會返回許多不相干的數(shù)據(jù)。這時候也需要在
like
后面加上
binary
操作符以進行二進制比較:
select
*
from
user
where
username
like
binary
'%小%'
提示
當在
like
匹配時加上
binary
操作符后,則會嚴格區(qū)分英文大小寫。因此當檢索的內容是中英文混合且需要忽略英文大小寫的時候,就會遇到麻煩。為解決此問題,需要引入
mysql
中的
upper()
與
concat()
函數(shù):
upper():將英文字符串變大寫,同ucase()
concat():將多個字符串連接成一個字符串
語法如下:
upper(str)
concat(str1,str2,...)
因此當我們要進行中英文混合匹配檢索且要忽略英文大小寫時,可以使用如下例所示的
sql
語句:
select
*
from
username
where
upper(username)
like
binary
concatt('%',upper('a中文b'),'%')
在該
sql
中,將搜索的字段及檢索的內容都進行大寫轉換后,再進行二進制匹配。
like
運算符的效率
like
運算符要對字段數(shù)據(jù)進行逐一掃描匹配,實際執(zhí)行的效率是較差的,哪怕該字段已經建有索引(a%
這種方式會用到索引)。當數(shù)據(jù)量較大時,要盡可能的減少
like
運算符的使用,也沒有太多優(yōu)化的余地。