- MySQL 基础
- MySQL - 首页
- MySQL - 简介
- MySQL - 特性
- MySQL - 版本
- MySQL - 变量
- MySQL - 安装
- MySQL - 管理
- MySQL - PHP 语法
- MySQL - Node.js 语法
- MySQL - Java 语法
- MySQL - Python 语法
- MySQL - 连接
- MySQL - Workbench
- MySQL 数据库
- MySQL - 创建数据库
- MySQL - 删除数据库
- MySQL - 选择数据库
- MySQL - 显示数据库
- MySQL - 复制数据库
- MySQL - 数据库导出
- MySQL - 数据库导入
- MySQL - 数据库信息
- MySQL 用户
- MySQL - 创建用户
- MySQL - 删除用户
- MySQL - 显示用户
- MySQL - 修改密码
- MySQL - 授予权限
- MySQL - 显示权限
- MySQL - 收回权限
- MySQL - 锁定用户账户
- MySQL - 解锁用户账户
- MySQL 表
- MySQL - 创建表
- MySQL - 显示表
- MySQL - 修改表
- MySQL - 重命名表
- MySQL - 克隆表
- MySQL - 截断表
- MySQL - 临时表
- MySQL - 修复表
- MySQL - 描述表
- MySQL - 添加/删除列
- MySQL - 显示列
- MySQL - 重命名列
- MySQL - 表锁定
- MySQL - 删除表
- MySQL - 派生表
- MySQL 查询
- MySQL - 查询
- MySQL - 约束
- MySQL - 插入查询
- MySQL - 选择查询
- MySQL - 更新查询
- MySQL - 删除查询
- MySQL - 替换查询
- MySQL - 插入忽略
- MySQL - 插入重复键更新
- MySQL - 插入到选择
- MySQL 运算符和子句
- MySQL - Where 子句
- MySQL - Limit 子句
- MySQL - Distinct 子句
- MySQL - Order By 子句
- MySQL - Group By 子句
- MySQL - Having 子句
- MySQL - AND 运算符
- MySQL - OR 运算符
- MySQL - Like 运算符
- MySQL - IN 运算符
- MySQL - ANY 运算符
- MySQL - EXISTS 运算符
- MySQL - NOT 运算符
- MySQL - 不等于运算符
- MySQL - IS NULL 运算符
- MySQL - IS NOT NULL 运算符
- MySQL - Between 运算符
- MySQL - UNION 运算符
- MySQL - UNION 与 UNION ALL
- MySQL - MINUS 运算符
- MySQL - INTERSECT 运算符
- MySQL - INTERVAL 运算符
- MySQL 连接
- MySQL - 使用连接
- MySQL - 内连接
- MySQL - 左连接
- MySQL - 右连接
- MySQL - 交叉连接
- MySQL - 全连接
- MySQL - 自连接
- MySQL - 删除连接
- MySQL - 更新连接
- MySQL - Union 与 Join
- MySQL 触发器
- MySQL - 触发器
- MySQL - 创建触发器
- MySQL - 显示触发器
- MySQL - 删除触发器
- MySQL - 插入前触发器
- MySQL - 插入后触发器
- MySQL - 更新前触发器
- MySQL - 更新后触发器
- MySQL - 删除前触发器
- MySQL - 删除后触发器
- MySQL 数据类型
- MySQL - 数据类型
- MySQL - VARCHAR
- MySQL - BOOLEAN
- MySQL - ENUM
- MySQL - DECIMAL
- MySQL - INT
- MySQL - FLOAT
- MySQL - BIT
- MySQL - TINYINT
- MySQL - BLOB
- MySQL - SET
- MySQL 正则表达式
- MySQL - 正则表达式
- MySQL - RLIKE 运算符
- MySQL - NOT LIKE 运算符
- MySQL - NOT REGEXP 运算符
- MySQL - regexp_instr() 函数
- MySQL - regexp_like() 函数
- MySQL - regexp_replace() 函数
- MySQL - regexp_substr() 函数
- MySQL 函数 & 运算符
- MySQL - 日期和时间函数
- MySQL - 算术运算符
- MySQL - 数字函数
- MySQL - 字符串函数
- MySQL - 聚合函数
- MySQL 杂项概念
- MySQL - NULL 值
- MySQL - 事务
- MySQL - 使用序列
- MySQL - 处理重复项
- MySQL - SQL 注入
- MySQL - 子查询
- MySQL - 注释
- MySQL - 检查约束
- MySQL - 存储引擎
- MySQL - 将表导出到 CSV 文件
- MySQL - 将 CSV 文件导入数据库
- MySQL - UUID
- MySQL - 公共表表达式
- MySQL - On Delete Cascade
- MySQL - Upsert
- MySQL - 水平分区
- MySQL - 垂直分区
- MySQL - 游标
- MySQL - 存储函数
- MySQL - Signal
- MySQL - Resignal
- MySQL - 字符集
- MySQL - 校对
- MySQL - 通配符
- MySQL - 别名
- MySQL - ROLLUP
- MySQL - 今日日期
- MySQL - 字面量
- MySQL - 存储过程
- MySQL - Explain
- MySQL - JSON
- MySQL - 标准差
- MySQL - 查找重复记录
- MySQL - 删除重复记录
- MySQL - 选择随机记录
- MySQL - Show Processlist
- MySQL - 更改列类型
- MySQL - 重置自动递增
- MySQL - Coalesce() 函数
- MySQL 有用资源
- MySQL - 有用函数
- MySQL - 语句参考
- MySQL - 快速指南
- MySQL - 有用资源
- MySQL - 讨论
MySQL - 布尔全文搜索
MySQL 布尔全文搜索
MySQL 提供了全文搜索功能,支持三种类型的搜索,其中一种是布尔全文搜索。
这种布尔全文搜索通过允许使用布尔运算符(例如 +、-、>、<、* 等)和搜索字符串,能够对大量文本数据执行复杂的搜索操作。
与搜索概念的自然语言全文搜索不同,MySQL 中的布尔全文搜索查找特定单词。要执行此类搜索,需要在 AGAINST 表达式中包含IN BOOLEAN MODE 修饰符。
语法
以下是使用 IN BOOLEAN MODE 修饰符和 MySQL 中的 AGAINST 表达式执行布尔全文搜索的语法:
SELECT column_name(s) FROM table_name WHERE MATCH(target_column_names) AGAINST(expression IN BOOLEAN MODE);
其中,
- target_column_names 是我们要在其中搜索关键字的列的名称。
- expression 是带有布尔运算符的关键字列表。
MySQL 布尔全文搜索运算符
下表指定了全文搜索布尔运算符:
运算符 | 描述 |
---|---|
+ | 包含,该单词必须存在。 |
- | 排除,该单词必须不存在。 |
> | 包含,该单词必须存在,并且具有更高的优先级。 |
< | 包含,该单词必须存在,并且具有较低的优先级。 |
() | 将单词分组到子表达式中 |
示例
首先,让我们使用以下查询创建一个名为ARTICLES 的表:
CREATE TABLE ARTICLES ( ID INT AUTO_INCREMENT NOT NULL PRIMARY KEY, ARTICLE_TITLE VARCHAR(100), DESCRIPTION TEXT, FULLTEXT (ARTICLE_TITLE, DESCRIPTION) );
在上面的查询中,我们在ARTICLE_TITLE 和DESCRIPTION 列上定义了全文索引。现在,让我们将值插入到上面创建的表中:
INSERT INTO ARTICLES (ARTICLE_TITLE, DESCRIPTION) VALUES ('MySQL Tutorial', 'MySQL is a relational database system that uses SQL to structure data stored'), ('Java Tutorial', 'Java is an object-oriented and platform-independent programming languag'), ('Hadoop Tutorial', 'Hadoop is framework that is used to process large sets of data'), ('Big Data Tutorial', 'Big Data refers to data that has wider variety of data sets in larger numbers'), ('JDBC Tutorial', 'JDBC is a Java based technology used for database connectivity');
ARTICLES 表创建如下:
ID | ARTICLE_TITLE | DESCRIPTION |
---|---|---|
1 | MySQL 教程 | MySQL 是一个关系数据库系统,它使用 SQL 来构造存储的数据 |
2 | Java 教程 | Java 是一种面向对象且与平台无关的编程语言 |
3 | Hadoop 教程 | Hadoop 是一个用于处理大型数据集的框架 |
4 | 大数据教程 | 大数据是指具有更大数量和更广泛数据类型的更大数据集 |
5 | JDBC 教程 | JDBC 是一种基于 Java 的技术,用于数据库连接 |
现在,让我们在布尔模式下执行全文搜索,我们正在搜索包含单词“data”的行:
SELECT * FROM ARTICLES WHERE MATCH (ARTICLE_TITLE, DESCRIPTION) AGAINST('data' IN BOOLEAN MODE);
输出
如下面的输出所示,上面的查询返回了三行包含单词“data”的行:
ID | ARTICLE_TITLE | DESCRIPTION |
---|---|---|
4 | 大数据教程 | 大数据是指具有更大数量和更广泛数据类型的更大数据集 |
1 | MySQL 教程 | MySQL 是一个关系数据库系统,它使用 SQL 来构造存储的数据 |
3 | Hadoop 教程 | Hadoop 是一个用于处理大型数据集的框架 |
示例
在下面的查询中,我们正在搜索包含单词“data”但不包含“sets”的行:
SELECT * FROM ARTICLES WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE);
输出
上面查询的输出如下所示:
ARTICLE_TITLE | DESCRIPTION |
---|---|
MySQL 教程 | MySQL 是一个关系数据库系统,它使用 SQL 来构造存储的数据 |
示例
这里,我们正在搜索包含“data”和“set”这两个单词的行:
SELECT * FROM ARTICLES WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data +sets' IN BOOLEAN MODE);
输出
执行给定查询后,输出显示如下:
ID | ARTICLE_TITLE | DESCRIPTION |
---|---|---|
4 | 大数据教程 | 大数据是指具有更大数量和更广泛数据类型的更大数据集 |
3 | Hadoop 教程 | Hadoop 是一个用于处理大型数据集的框架 |
示例
在下面的查询中,我们正在搜索包含单词“set”的行,但对于包含“set”的行,其排名较低:
SELECT * FROM ARTICLES WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data sets' IN BOOLEAN MODE);
输出
当我们执行上面的查询时,获得的输出如下所示:
ID | ARTICLE_TITLE | DESCRIPTION |
---|---|---|
4 | 大数据教程 | 大数据是指具有更大数量和更广泛数据类型的更大数据集 |
3 | Hadoop 教程 | Hadoop 是一个用于处理大型数据集的框架 |
1 | MySQL 教程 | MySQL 是一个关系数据库系统,它使用 SQL 来构造存储的数据 |
示例
使用以下查询,我们正在搜索包含单词“data”的行,如果它包含单词“tutorial”,则将该特定记录在搜索中的排名降低:
SELECT * FROM ARTICLES WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data ~sets' IN BOOLEAN MODE);
输出
执行给定查询后,输出显示如下:
ID | ARTICLE_TITLE | DESCRIPTION |
---|---|---|
4 | 大数据教程 | 大数据是指具有更大数量和更广泛数据类型的更大数据集 |
1 | MySQL 教程 | MySQL 是一个关系数据库系统,它使用 SQL 来构造存储的数据 |
3 | Hadoop 教程 | Hadoop 是一个用于处理大型数据集的框架 |
示例
这里,我们找到所有包含以“set”开头的单词的行:
SELECT * FROM ARTICLES WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('set*' IN BOOLEAN MODE);
输出
执行给定查询后,输出显示如下:
ID | ARTICLE_TITLE | DESCRIPTION |
---|---|---|
3 | Hadoop 教程 | Hadoop 是一个用于处理大型数据集的框架 |
4 | 大数据教程 | 大数据是指具有更大数量和更广泛数据类型的更大数据集 |
MySQL 布尔全文搜索特性
以下是 MySQL 布尔全文搜索的一些重要特性:
- 在布尔全文搜索中,MySQL 不会自动按相关性降序对行进行排序。
- InnoDB 表要求 MATCH 表达式的所有列都具有 FULLTEXT 索引才能执行布尔查询。
- 如果我们在 InnoDB 表上对搜索查询提供多个布尔运算符,例如 '++hello',MySQL 不支持它们,并且会生成错误。但是,如果我们在 MyISAM 中执行相同的操作,它会忽略额外的运算符并使用最靠近搜索词的运算符。
- InnoDB 全文搜索不支持尾随的 (+) 或 (-) 符号。它只支持前导的 + 或 - 符号。
- 如果搜索词是 'hello+' 或 'hello-',MySQL 将会生成错误。此外,以下内容也会生成错误:'+*'、'+-'。
- 如果某个词出现在超过 50% 的行中,MySQL 会忽略搜索结果中的该词。这称为 50% 阈值。
使用客户端程序进行布尔全文搜索
我们还可以使用客户端程序在 MySQL 数据库上执行布尔全文搜索操作。
语法
要通过 PHP 程序执行布尔全文搜索,我们需要使用 **mysqli** 函数 **query()** 执行以下 SELECT 语句,如下所示:
$sql = "SELECT * FROM articles WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE)"; $mysqli->query($sql);
要通过 JavaScript 程序执行布尔全文搜索,我们需要使用 **mysql2** 库的 **query()** 函数执行以下 SELECT 语句,如下所示:
sql = `SELECT * FROM articles WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE)`; con.query(sql);
要通过 Java 程序执行布尔全文搜索,我们需要使用 **JDBC** 函数 **executeQuery()** 执行 SELECT 语句,如下所示:
String sql = "SELECT * FROM articles WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE)"; statement.executeQuery(sql);
要通过 Python 程序执行布尔全文搜索,我们需要使用 **MySQL Connector/Python** 的 **execute()** 函数执行 SELECT 语句,如下所示:
boolean_fulltext_search_query = 'select * from articles where MATCH (ARTICLE_TITLE, DESCRIPTION) AGAINST('data' IN BOOLEAN MODE)' cursorObj.execute(boolean_fulltext_search_query)
示例
以下是程序示例:
$dbhost = 'localhost'; $dbuser = 'root'; $dbpass = 'password'; $dbname = 'TUTORIALS'; $mysqli = new mysqli($dbhost, $dbuser, $dbpass, $dbname); if ($mysqli->connect_errno) { printf("Connect failed: %s
", $mysqli->connect_error); exit(); } // printf('Connected successfully.
'); //creating a table Articles that stores fulltext. $sql = "CREATE TABLE Articles (ID INT AUTO_INCREMENT NOT NULL PRIMARY KEY, ARTICLE_TITLE VARCHAR(100), DESCRIPTION TEXT, FULLTEXT (ARTICLE_TITLE, DESCRIPTION))"; $result = $mysqli->query($sql); if ($result) { printf("Table created successfully...!\n"); } //insert data $q = "INSERT INTO Articles (ARTICLE_TITLE, DESCRIPTION) VALUES ('MySQL Tutorial', 'MySQL is a relational database system that uses SQL to structure data stored'), ('Java Tutorial', 'Java is an object-oriented and platform-independent programming languag'), ('Hadoop Tutorial', 'Hadoop is framework that is used to process large sets of data'), ('Big Data Tutorial', 'Big Data refers to data that has wider variety of data sets in larger numbers'), ('JDBC Tutorial', 'JDBC is a Java based technology used for database connectivity')"; if ($res = $mysqli->query($q)) { printf("Data inserted successfully...!\n"); } $s = "SELECT * FROM articles WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE)"; if ($r = $mysqli->query($s)) { printf("Table Records: \n"); while ($row = $r->fetch_assoc()) { printf(" ID: %d, Title: %s, Descriptions: %s", $row["id"], $row["ARTICLE_TITLE"], $row["DESCRIPTION"]); printf("\n"); } } else { printf('Failed'); } $mysqli->close();
输出
获得的输出如下所示:
Table created successfully...! Data inserted successfully...! Table Records: ID: 1, Title: MySQL Tutorial, Descriptions: MySQL is a relational database system that uses SQL to structure data stored
var mysql = require("mysql2"); var con = mysql.createConnection({ host: "localhost", user: "root", password: "password", }); //Connecting to MySQL con.connect(function (err) { if (err) throw err; // console.log("Connected successfully...!"); // console.log("--------------------------"); sql = "USE TUTORIALS"; con.query(sql); sql = "CREATE TABLE Articles (ID INT AUTO_INCREMENT NOT NULL PRIMARY KEY, ARTICLE_TITLE VARCHAR(100), DESCRIPTION TEXT, FULLTEXT (ARTICLE_TITLE, DESCRIPTION) )"; con.query(sql); //insert data into created table sql = `INSERT INTO Articles (ARTICLE_TITLE, DESCRIPTION) VALUES ('MySQL Tutorial', 'MySQL is a relational database system that uses SQL to structure data stored'), ('Java Tutorial', 'Java is an object-oriented and platform-independent programming languag'), ('Hadoop Tutorial', 'Hadoop is framework that is used to process large sets of data'), ('Big Data Tutorial', 'Big Data refers to data that has wider variety of data sets in larger numbers'), ('JDBC Tutorial', 'JDBC is a Java based technology used for database connectivity')`; con.query(sql); //display the table details!... sql = `SELECT * FROM articles WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE)`; con.query(sql, function (err, result) { if (err) throw err; console.log(result); }); });
输出
获得的输出如下所示:
[ { id: 1, ARTICLE_TITLE: 'MySQL Tutorial', DESCRIPTION: 'MySQL is a relational database system that uses SQL to structure data stored' } ]
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class BooleanFulltextSearch { public static void main(String[] args) { String url = "jdbc:mysql://127.0.0.1:3306/TUTORIALS"; String username = "root"; String password = "password"; try { Class.forName("com.mysql.cj.jdbc.Driver"); Connection connection = DriverManager.getConnection(url, username, password); Statement statement = connection.createStatement(); System.out.println("Connected successfully...!"); //creating a table that takes fulltext column...! String sql = "CREATE TABLE Articles (ID INT AUTO_INCREMENT NOT NULL PRIMARY KEY, ARTICLE_TITLE VARCHAR(100), DESCRIPTION TEXT, FULLTEXT (ARTICLE_TITLE, DESCRIPTION) )"; statement.execute(sql); System.out.println("Table created successfully...!"); //inserting data to the table String insert = "INSERT INTO Articles (ARTICLE_TITLE, DESCRIPTION) VALUES" + "('MySQL Tutorial', 'MySQL is a relational database system that uses SQL to structure data stored')," + "('Java Tutorial', 'Java is an object-oriented and platform-independent programming languag')," + "('Hadoop Tutorial', 'Hadoop is framework that is used to process large sets of data')," + "('Big Data Tutorial', 'Big Data refers to data that has wider variety of data sets in larger numbers')," + "('JDBC Tutorial', 'JDBC is a Java based technology used for database connectivity')"; statement.execute(insert); System.out.println("Data inserted successfully...!"); //displaying the fulltext records in the boolean mode: ResultSet resultSet = statement.executeQuery("SELECT * FROM articles WHERE MATCH(ARTICLE_TITLE, DESCRIPTION) AGAINST('+data -sets' IN BOOLEAN MODE)"); while (resultSet.next()){ System.out.println(resultSet.getString(1)+" "+resultSet.getString(2)+ " "+resultSet.getString(3)); } connection.close(); } catch (Exception e) { System.out.println(e); } } }
输出
获得的输出如下所示:
Connected successfully...! Table created successfully...! Data inserted successfully...! 1 MySQL Tutorial MySQL is a relational database system that uses SQL to structure data stored
import mysql.connector # Establishing the connection connection = mysql.connector.connect( host='localhost', user='root', password='password', database='tut' ) # Creating a cursor object cursorObj = connection.cursor() boolean_fulltext_search_query = f"select * from articles where MATCH (ARTICLE_TITLE, DESCRIPTION) AGAINST('data' IN BOOLEAN MODE)" cursorObj.execute(boolean_fulltext_search_query) # Fetching all the results results = cursorObj.fetchall() # Display the result print("Boolean Fulltext search results:") for row in results: print(row) cursorObj.close() connection.close()
输出
获得的输出如下所示:
Boolean Fulltext search results: (4, 'Big Data Tutorial', 'Big Data refers to data that has wider variety of data sets in larger numbers') (1, 'MySQL Tutorial', 'MySQL is a relational database system that uses SQL to structure data stored') (3, 'Hadoop Tutorial', 'Hadoop is framework that is used to process large sets of data')