select * from information_schema.COLUMNS where COLUMN_NAME='love';
数据库information_schema里有存表的各种信息
Ⅱ 如何使用mysql的全文索引搜索
你有没有想过如何使用搜索功能在所有整站中实现!互联网博客和网站,大多数都采用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索引定义,除非这场比赛()是在布尔模式。布尔模式搜索,可以做非索引列,虽然他们很可能是缓慢的。
Ⅲ PHP lucene 结合实现对mysql数据库的全文搜索,求前辈指点
你的意图是什么?是从数据库层面建立索引,如对数据库的关联表建立索引,每次全文检索时,直接从索引库进行检索,不再对数据库进行最大模糊匹配,是吧?这样的话,建议查看Solr+关系数据库操作
Ⅳ mysql怎样查询一个表中所有数据
输出所有的字段及不使用谓词如distinct,limit等、不分组汇总、不附加任何筛选条件和实施任何连接即可检索出该表的所有数据。
例如下列语句:
select * from t1(* 号表示输出所有的字段)
Ⅳ Lucene可以对MYSQL进行全文检索吗
Lucene是可以的,它常见的用例就是在一个或者多个数据库表进行全文检索。 虽然MySql有全文检索的功能,但是如果字段和数据量增加,MySql的性能会减低很快。
Ⅵ 搞定MySQL数据库中文模糊检索问题
在MySQL下,在进行中文模糊检索时,经常会返回一些与之不相关的记录,如查找“%a%”时,返回的可能有中文字符,却没有a字符存在。本人以前也曾遇到过类似问题,经详细阅读MySQL的Manual,发现可以有一种方法很方便的解决并得到满意的结果。
例子:
希望通过“标题”对新闻库进行检索,关键字可能包含是中英文,如下SQL语句:
QUOTE:
select
id,title,name
from
achech_com.news
where
title
like
'%a%'
返回的结果,某些title字段确定带了“a”关键字,而有些则只有中文,但也随之返回在检索结果中。
解决方法,使用BINARY属性进行检索,如:
QUOTE:
select
id,title,name
from
achech_com.news
where
binary
title
like
'%a%'
返回的结果较之前正确,但英文字母区分大小写,故有时在检索如“Achech”及“achech”的结果是不一样的。知道了使用BINARY属性可以解
决前面这个问题,再看看MySQL支持的UCASE及CONCAT函数,其中UCASE是将英文全部转成大写,而CONCAT函数的作用是对字符进行连
接,以下是我们完全解决后的SQL语句:
QUOTE:
select
id,title,name
from
achech_com.news
where
binary
ucase(title)
like
concat('%',ucase('a'),'%')
检索的步骤是先将属性指定为BINARY,以精确检索结果,而被like的title内容存在大小写字母的可能,故先使用ucase函数将字段内容全部
转换成大写字母,然后再进行like操作,而like的操作使用模糊方法,使用concat的好处是传进来的可以是直接的关键字,不需要带“%”万用符,
将“'a'”直接换成你的变量,在任何语言下都万事无忧了。当然你也可以这么写:
QUOTE:
select
id,title,name
from
achech_com.news
where
binary
ucase(title)
like
ucase('%a%')
检索的结果还算满意吧,不过速度可能会因此而慢N毫秒。
Ⅶ mysql 怎么搜索一个数据库中的所有表
show
tables
可以显示当前数据库下的所有表。
但是如果你想要查找特定的表
可能不大容易实现。
如果前缀都为a
可以试试
show
table
like
'a%';
Ⅷ 怎么用mysql查询全表最大字段值的数据
select * from 表 order by 要最大值的字段 desc limit 0,10
Ⅸ MYSQL 的全文检索 MATCH()AGAINST
目前,MySQL全文检索不支持中文和日文。