找到关于数据库的6705 篇文章

MySQL IN() 函数何时返回 NULL?

Arjun Thakur
更新于 2020年6月22日 06:36:43

292 次浏览

以下两种情况下,MySQL IN() 函数将返回 NULL 结果:情况一 - 当左侧表达式为 NULL 时,如果左侧表达式为 NULL,IN() 函数将返回 NULL。以下示例将演示它:mysql> Select NULL IN (1, 2, 3, 4, 10); +----------------------+ | NULL IN (1, 2, 3, 4, 10) | +----------------------+ | NULL | +----------------------+ 1 row in set (0.00 sec)情况二 - 当列表中的一个表达式为 NULL 且未找到匹配项时,如果…… 阅读更多

如何删除 MySQL 存储过程?

Daniol Thomas
更新于 2020年6月22日 06:55:19

224 次浏览

如果我们对该过程具有 ALTER ROUTINE 权限,那么我们可以使用 DROP PROCEDURE 语句删除 MySQL 存储过程。为了演示这一点,我们删除名为“coursedetails”的存储过程,如下所示:mysql> DROP PROCEDURE coursedetails; Query OK, 0 rows affected (0.68 sec)上述查询将删除名为“coursedetails”的过程。可以通过运行 SHOW CREATE PROCEDURE 语句来确认,该语句将返回错误,因为该过程不存在。

如何修改 MySQL 存储过程?

Prabhas
更新于 2020年6月22日 06:54:46

719 次浏览

如果我们对该过程具有 ALTER ROUTINE 权限,那么我们可以使用 ALTER PROCEDURE 语句修改 MySQL 存储过程。为了演示这一点,我们以名为“delete_studentinfo”的存储过程为例,该过程具有以下创建语句:mysql> SHOW CREATE PROCEDURE Delete_studentinfo\G *************************** 1. row *************************** Procedure: Delete_studentinfo sql_mode: ONLY_FULL_GROUP_BY, STRICT_TRANS_TABLES, NO_ZERO_IN_DATE, NO_ ZERO_DATE, ERROR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER, NO_ENGINE_SUBSTITUTION Create Procedure: CREATE DEFINER=`root`@`localhost` PROCEDURE `Delete_studentinfo`( IN p_id INT) BEGIN DELETE FROM student_info WHERE ID=p_id; END character_set_client: cp850 collation_connection: cp850_general_ci Database Collation: ... 阅读更多

如何编写 MySQL 存储过程来从表中选择所有数据?

Priya Pallavi
更新于 2020年2月12日 07:53:37

993 次浏览

为了演示这一点,我们创建一个名为“selectdetails()”的过程,它将从“student_detail”表中获取所有记录。mysql> Delimiter // mysql> Create Procedure selectdetails() -> BEGIN -> Select * from student_detail; -> END// Query OK, 0 rows affected (0.00 sec)现在,调用此过程后,我们将从“student_detail”表中获取所有记录。mysql> Delimiter ; mysql> CALL selectdetails(); +-----------+-------------+------------+ | Studentid | StudentName | address | +-----------+-------------+------------+ | 100 | Gaurav | Delhi | | 101 | Raman | Shimla | | 103 | Rahul | Jaipur | | 104 | Ram | Chandigarh | | 105 | Mohan | Chandigarh | +-----------+-------------+------------+ 5 rows in set (0.00 sec) Query OK, 0 rows affected (0.01 sec)

如何在存储过程中编写 MySQL 处理程序,该处理程序使用 SQLSTATE 来处理默认的 MySQL 错误并退出执行?

seetha
更新于 2020年2月12日 07:57:10

456 次浏览

众所周知,每当在 MySQL 存储过程中发生异常时,通过抛出适当的错误消息来处理它非常重要,因为如果不处理异常,则有可能导致应用程序因存储过程中的该异常而失败。MySQL 提供了一个处理程序,该处理程序使用 SQLSTATE 来处理默认的 MySQL 错误并退出执行。为了演示这一点,我们使用以下示例,在该示例中,我们尝试在主键列中插入重复值。示例mysql> Delimiter // mysql> Create Procedure Insert_Studentdetails4(S_Studentid INT, S_StudentName Varchar(20), S_Address Varchar(20), OUT got_error ... 阅读更多

如何在存储过程中编写 MySQL 处理程序,该处理程序会抛出错误消息并退出执行?

Nikitha N
更新于 2020年6月22日 06:45:04

543 次浏览

众所周知,每当在 MySQL 存储过程中发生异常时,通过抛出适当的错误消息来处理它非常重要,因为如果不处理异常,则有可能导致应用程序因存储过程中的该异常而失败。MySQL 提供了一个处理程序,该处理程序会抛出错误消息并退出执行。为了演示这一点,我们使用以下示例,在该示例中,我们尝试在主键列中插入重复值。示例mysql> Delimiter // mysql> Create Procedure Insert_Studentdetails3(S_Studentid INT, S_StudentName Varchar(20), S_Address Varchar(20)) -> BEGIN ... 阅读更多

如何在存储过程中编写 MySQL 处理程序,该处理程序设置变量的特定值并继续执行?

Krantik Chavan
更新于 2020年2月12日 08:02:43

183 次浏览

众所周知,每当在 MySQL 存储过程中发生异常时,通过抛出适当的错误消息来处理它非常重要,因为如果不处理异常,则有可能导致应用程序因存储过程中的该异常而失败。MySQL 提供了一个处理程序,该处理程序设置变量的特定值并继续执行。为了演示这一点,我们使用以下示例,在该示例中,我们尝试在主键列中插入重复值。mysql> DELIMITER // mysql> Create Procedure Insert_Studentdetails2(S_Studentid INT, S_StudentName Varchar(20), S_Address Varchar(20), OUT ... 阅读更多

如何在存储过程中编写 MySQL 处理程序,该处理程序会抛出错误消息并继续执行?

vanithasree
更新于 2020年2月12日 08:00:57

632 次浏览

众所周知,每当在 MySQL 存储过程中发生异常时,通过抛出适当的错误消息来处理它非常重要,因为如果不处理异常,则有可能导致应用程序因存储过程中的该异常而失败。MySQL 提供了一个处理程序,该处理程序会抛出错误消息并继续执行。为了演示这一点,我们使用以下示例,在该示例中,我们尝试在主键列中插入重复值。示例mysql> DELIMITER // mysql> Create Procedure Insert_Studentdetails(S_Studentid INT, S_StudentName Varchar(20), S_Address Varchar(20)) -> BEGIN ... 阅读更多

为什么不建议在 MySQL IN() 函数的列表中混合使用带引号和不带引号的值?

George John
更新于 2019年7月30日 22:30:21

64 次浏览

实际上,MySQL 对带引号的值(例如字符串)和不带引号的值(例如数字)有不同的比较规则。在 IN() 函数列表中混合带引号和不带引号的值可能会导致结果集不一致。例如,我们不应编写如下使用 IN() 函数的查询:Select Salary from employee where ID IN(1,’a’,2,3,’c’) 更好的方法是如下所示:Select Salary from employee where ID IN(‘1’,’a’,’2’,’3’,’c’)

如何使用 MySQL IN() 函数根据与列名进行的比较来获取输出?

Monica Mona
更新于 2020年6月22日 06:38:53

浏览量:91

在这种情况下,我们需要使用列名作为“表达式”,然后将其与列表中的值进行比较。如果列的值在列表中匹配,则会产生输出。为了理解这一点,请考虑来自 employee 表的以下数据示例:mysql> Select * from Employee; +----+--------+--------+ | ID | Name | Salary | +----+--------+--------+ | 1 | Gaurav | 50000 | | 2 | Rahul | 20000 | | 3 | Advik | 25000 | | 4 | Aarav | 65000 | | 5 | Ram | 20000 | ... 阅读更多

广告