找到 4219 篇文章 关于 MySQLi

如何检查数据库中所有触发器的列表?

Manikanth Mani
更新于 2020-06-22 11:52:21

179 次浏览

借助 SHOW TRIGGERS 语句,我们可以列出特定数据库中的所有触发器。以下示例可以说明这一点:示例mysql> Show Triggers\G *************************** 1. row *************************** Trigger: trigger_before_delete_sample Event: DELETE Table: sample Statement: BEGIN SET @count = if (@count IS NULL, 1, (@count+1)); INSERT INTO sample_rowaffected values (@count); END Timing: BEFORE Created: 2017-11-21 12:31:58.70 sql_mode: ONLY_FULL_GROUP_BY, STRICT_TRANS_TABLES, NO_ZERO_IN_DATE, NO_ZERO_DATE, ERR OR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER, NO_ENGINE_SUBSTITUTION Definer: root@localhost character_set_client: cp850 collation_connection: cp850_general_ci Database Collation: latin1_swedish_ci *************************** 2. ... 阅读更多

如何在 MySQL 结果集本身中获取列的汇总输出?

Anvi Jain
更新于 2020-06-22 11:46:57

507 次浏览

我们可以通过使用“WITH ROLLUP”修饰符来获取 MySQL 结果集中列的汇总输出。此修饰符与 GROUP BY 子句一起使用。它提供的汇总输出包含表示更高级别汇总操作的额外行。示例在此示例中,“WITH ROLLUP”修饰符在额外行中提供了包含总成本值的汇总输出。mysql> Select Item_name, SUM(Cost) AS Total_cost from Item_list GROUP BY Item_name WITH ROLLUP; +-----------+------------+ | Item_name | Total_cost | +-----------+------------+ | Notebook | 45.00 | | Pen | 31.70 | | Pencilbox | 125.20 | | NULL | 201.90 | +-----------+------------+ 4 rows in set (0.00 sec)

MySQL 结果集中的“空集”是什么意思?

Nitya Raut
更新于 2020-06-22 11:53:16

5K+ 次浏览

如果 MySQL 查询的结果集中存在“空集”,则表示 MySQL 没有返回任何行,并且查询也没有错误。以下示例可以帮助理解这一点:mysql> Select * from Student_info WHERE Name = 'ABCD'; Empty set (0.00 sec)我们可以看到空集和执行时间作为输出。这意味着查询是正确的,但是 MySQL 表中不存在名为“ABCD”的名称。

使用 MySQL 触发器的优点、缺点和限制是什么?

Fendadis John
更新于 2020-06-22 11:50:53

4K+ 次浏览

我们必须了解使用 MySQL 触发器的优点、缺点和限制,以便有效地使用它。优点以下是使用 MySQL 触发器的优点:数据完整性 - 使用 MySQL 触发器,我们可以检查表中数据的完整性。换句话说,MySQL 触发器是检查数据完整性的替代方法。用于捕获错误 - MySQL 触发器可以在数据库层捕获业务逻辑中的错误。运行计划任务的替代方法 - 实际上,使用 MySQL 触发器,我们不必等待运行计划任务,因为... 阅读更多

如何在 MySQL 语句处理过程中将其丢弃?

Prabhas
更新于 2020-06-22 11:51:28

69 次浏览

借助 \c 命令,我们可以在 MySQL 语句处理过程中将其丢弃。考虑以下示例,在语句中间我们想要丢弃它,然后我们为此使用 \c 选项:mysql> Select * -> from\c mysql>上面的查询显示,在使用 \c 选项后,MySQL 会丢弃该语句并返回到提示符。

如何在 MySQL 中使用 SELECT(不引用任何表)计算表达式?

Govinda Sai
更新于 2020-06-22 11:49:51

83 次浏览

借助以下 MySQL 语句,我们可以使用 SELECT 计算表达式:SELECT expression;上述语句没有引用任何表。以下是一些示例:mysql> Select 10 DIV 5; +----------+ | 10 DIV 5 | +----------+ | 2 | +----------+ 1 row in set (0.06 sec) mysql> Select 10*5; +------+ | 10*5 | +------+ | 50 | +------+ 1 row in set (0.00 sec) mysql> Set @var1 = 100, @var2 = 200; Query OK, 0 rows affected (0.00 sec) mysql> Select @Var1+@Var2; +-------------+ | @Var1+@Var2 | +-------------+ | 300 | +-------------+ 1 row in set (0.00 sec)

MySQL 触发器中的“FOR EACH ROW”是如何工作的?

Samual Sam
更新于 2020-06-22 11:54:52

5K+ 次浏览

实际上,“FOR EACH ROW”表示对于每个匹配的行(被更新或删除的行)。换句话说,我们可以说触发器不会应用于每一行,它只是说对每个受影响的表行执行触发器体。我们可以通过以下示例来说明这一点:示例在此示例中,我们创建了两个表 Sample 和 Sample_rowaffected,如下所示:mysql> Create table Sample(id int, value varchar(20)); Query OK, 0 rows affected (0.47 sec) mysql> Insert into Sample(id, value) values(100, 'same'), (101, 'Different'), (500, 'excellent'), (501, 'temporary'); Query OK, 4 rows affected (0.04 sec) ... 阅读更多

在编写 MySQL 语句时,“c”选项有什么用?

Ramu Prasad
更新于 2020-06-22 11:40:20

402 次浏览

“\c”选项表示“清除”,用于清除当前输入。假设我们不想执行正在输入的命令,那么我们可以使用清除 \c 选项来清除当前输入。例如,\c 选项的使用可以如下所示:mysql> Select * -> from\c在上面的示例中,当我们在语句中使用 \c 时,MySQL 会清除当前输入并返回到 MySQL 提示符以接受其他语句。

MySQL 如何评估写在不同行上的语句?

Jennifer Nicholas
更新于 2020-06-22 11:53:48

77 次浏览

实际上,MySQL 在获得终止分号时确定语句的结束位置。假设我们在不同行上编写单个语句,那么在编写第一行后,MySQL 会将提示符从“mysql>”更改为“->”,这表示 MySQL 尚未看到完整的语句,并且正在等待其余部分。当它得到分号时,MySQL 会执行该语句。以下示例可以帮助理解这一点:示例mysql> Select Id, Name -> From -> Student_info -> ; +------+---------+ | Id | Name | +------+---------+ ... 阅读更多

如何使用不带 FROM 子句的 MySQL SELECT?

Sravani S
更新于 2020-06-22 11:42:35

1K+ 次浏览

SELECT 后的 FROM 子句显示对表的引用。但是,如果没有对任何表的引用,我们可以使用不带 FROM 子句的 SELECT。换句话说,我们可以说 SELECT 可用于检索无需引用任何表即可计算的行。考虑以下语句:mysql> Select concat_ws(" ","Hello", "World"); +---------------------------------+ | concat_ws(" ","Hello", "World") | +---------------------------------+ | Hello World | +---------------------------------+ 1 row in set (0.00 sec) mysql> Set @var1=100; Query OK, 0 rows affected (0.00 sec) mysql> Select @var1; +-------+ | @var1 | +-------+ | 100 | +-------+ 1 row in set (0.00 sec)

广告