SELECT * FROM t WHERE (unix_timestamp(NOW()) - create_time) <300
view sourceprint?01.
DELIMITER
02.
03.
DROP FUNCTION IF EXISTS urlencode
04.
05.
DELIMITER |
06.
07.
CREATE FUNCTION urlencode (s VARCHAR(4096)) RETURNS VARCHAR(4096)08.
DETERMINISTIC
09.
CONTAINS SQL
10.
BEGIN
11.
DECLARE c VARCHAR(4096) DEFAULT ''
12.
DECLARE pointer INT DEFAULT 1
13.
DECLARE s2 VARCHAR(4096) DEFAULT ''
14.
15.
IF ISNULL(s) THEN
16.
RETURN NULL
17.
ELSE
18.
SET s2 = ''
19.
WHILE pointer <= length(s) DO
20.
SET c = MID(s,pointer,1)
21.
IF c = ' ' THEN
22.
SET c = '+'
23.
ELSEIF NOT (ASCII(c) BETWEEN 48 AND 57 OR24.
ASCII(c) BETWEEN 65 AND 90 OR
25.
ASCII(c) BETWEEN 97 AND 122) THEN
26.
SET c = concat("%",LPAD(CONV(ASCII(c),10,16),2,0))27.
END IF
28.
SET s2 = CONCAT(s2,c)
29.
SET pointer = pointer + 1
30.
END while
31.
END IF
32.
RETURN s2
33.
END
34.
|
35.
DELIMITER
view sourceprint?
01.
DROP FUNCTION IF EXISTS urldecode
02.
03.
DELIMITER |
04.
05.
CREATE FUNCTION urldecode (s VARCHAR(4096)) RETURNS VARCHAR(4096)06.
DETERMINISTIC
07.
CONTAINS SQL
08.
BEGIN
09.
DECLARE c VARCHAR(4096) DEFAULT ''
10.
DECLARE pointer INT DEFAULT 1
11.
DECLARE h CHAR(2)
12.
DECLARE h1 CHAR(1)
13.
DECLARE h2 CHAR(1)
14.
DECLARE s2 VARCHAR(4096) DEFAULT ''
15.
16.
IF ISNULL(s) THEN
17.
RETURN NULL
18.
ELSE
19.
SET s2 = ''
20.
WHILE pointer <= LENGTH(s) DO
21.
SET c = MID(s,pointer,1)
22.
IF c = '+' THEN
23.
SET c = ' '
24.
ELSEIF c = '%' AND pointer + 2 <= LENGTH(s) THEN25.
SET h1 = LOWER(MID(s,pointer+1,1))
26.
SET h2 = LOWER(MID(s,pointer+2,1))
27.
IF (h1 BETWEEN '0' AND '9' OR h1 BETWEEN 'a' AND 'f')28.
AND
29.
(h2 BETWEEN '0' AND '9' OR h2 BETWEEN 'a' AND 'f')30.
THEN
31.
SET h = CONCAT(h1,h2)
32.
SET pointer = pointer + 2
33.
SET c = CHAR(CONV(h,16,10))
34.
END IF
35.
END IF
36.
SET s2 = CONCAT(s2,c)
37.
SET pointer = pointer + 1
38.
END while
39.
END IF
40.
RETURN s2
41.
END
42.
43.
|
44.
45.
DELIMITER
当一个字符串经过多次 urlencode 处理之后,可以使用 multiurldecode来解码,它将多次调用 urldecode来解码,直到没有需要解码的字符www.it165.net
view sourceprint?
01.
DELIMITER
02.
03.
DROP FUNCTION IF EXISTS multiurldecode
04.
05.
DELIMITER |
06.
07.
CREATE FUNCTION multiurldecode (s VARCHAR(4096)) RETURNS VARCHAR(4096)08.
DETERMINISTIC
09.
CONTAINS SQL
10.
BEGIN
11.
DECLARE pr VARCHAR(4096) DEFAULT ''
12.
IF ISNULL(s) THEN
13.
RETURN NULL
14.
END IF
15.
REPEAT
16.
SET pr = s
17.
SELECT urldecode(s) INTO s
18.
UNTIL pr = s END REPEAT
19.
RETURN s
20.
END
21.
22.
|
23.
24.
DELIMITER
你有没有想过如何使用搜索功能在所有整站中实现!互联网博客和网站,大多数都采用MySQL数据库。MySQL提供了一个美妙的方式实施一个小的搜索引擎,在您的网站(全文检索)。所有您需要做的是拥有的MySQL 4.x及以上。MySQL提供全文检索功能,我们可以用它来 ??实现搜索功能。
首先,让我们为我们的例子中设置一个示例表。我们将创建一个名为第一个表。
CREATE TABLE articles (
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
title VARCHAR(200),
body TEXT,
FULLTEXT (title,body)
)
在此表中还可以添加一些示例数据。执行后,插入查询。
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 ...')
一旦样本数据是准备好,我们可以开始我们的全文检索功能。
自然语言全文搜索
尝试我们的示例表上执行下面的SELECT查询。
SELECT * FROM articles
WHERE MATCH (title,body) AGAINST ('database')
你就能看到结果如下:
在下面的数据库比较5 MySQL与YourSQL的...
MySQL教程DBMS 1代表数据库...
我们在上面的SQL查询(标题,正文)反对(“数据库”)的比赛,选择所有的记录,列标题和正文进行全文搜索。
您可以修改该查询,并创建您自己的版本,以自己的数据库中执行全文搜索。
布尔全文搜索
它可能发生,你要指定某些关键字在您的搜索条件。此外,您可能要忽略某些关键字。布尔全文搜索可以用来执行这些要求的全文检索。
检查下面的SELECT查询。
SELECT * FROM articles WHERE MATCH (title,body)
AGAINST ('+MySQL -YourSQL' IN BOOLEAN MODE)
如果您发现上述选择查询,我们增加了布尔MODE反对()。这个查询将获取MySQL的关键字,但不YourSQL关键字的所有记录。请注意+和-我们以前指定的关键字!
在执行此功能,MySQL使用什么有时也被称为布尔逻辑作为暗示,其中:+代表与-代表不是[无 *** 作员]暗示或
以下是几个例子布尔搜索条件。
“苹果香蕉
查找行至少包含两个词之一。
“+苹果+果汁”
寻找包含两个单词的行。
“+苹果Macintosh
查找行包含“苹果”,但排名的行,如果它们也包含“麦金塔”。
“+苹果Macintosh的”
查找行包含“苹果”这个词,而不是“麦金塔”。
'+苹果Macintosh的“
查找包含单词“苹果”的行,但如果该行也包含单词“麦金塔”,速度比如果行不低。这是“软”比“+苹果Macintosh电脑”,为“麦金塔”的存在,导致该行不能在所有返回的搜索。
'+苹果+(>营业额<馅饼)“
行包含“苹果”和“营业额”,或“苹果”和“馅饼”(任何顺序)的话,但排名“苹果的营业额”比“苹果馅饼“。
限制
支持全文检索的MyISAM表只。MySQL 4.1中,使用多个字符设置一个单一的表内的支持。然而,在一个FULLTEXT索引的所有列,必须使用相同的字符集和校对规则。MATCH()列列表必须匹配完全在一些列清单表的FULLTEXT索引定义,除非这场比赛()是在布尔模式。布尔模式搜索,可以做非索引列,虽然他们很可能是缓慢的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)