这一节将重点讨论促使MySQL风行的一些关键特性。接下来,还将提供有关MySQL产品两个主要里程碑版本的重要信息。庞大的开源社区:MySQL之所以如此流行和受欢迎,很大一部分功劳要归功于开源社区的积极支持。在开源社区中不仅能了解到MySQL的最新发展动态,还能快速地解决一些问题和难题。......
2023-10-29
在存储过程中完成任务时,通常需要局部变量作为临时占位符。但是与PHP不同,MySQL要求指定这些变量的类型并显式进行声明。本节展示何声明和设置变量。
1.声明变量
与PHP不同,在存储过程使用局部变量之前,必须声明局部变量,通过使用MySQL支持的某种数据类型来指定变量类型。变量声明通过DECLARE语句实现,其形式如下:
例如,假设创建一个存储过程calculate- bonus来计算员工的红利。它可能需要变量salary、bonus和total。声明如下:
在声明变量时,声明必须放在BEGIN/END块中。此外,声明必须在执行该块任何其他语句之前进行。还要注意变量的作用范围限制在声明该变量的代码块中,这很重要,因为程序中可能有多个BEGIN/END块。
DECLARE关键字还用于声明某种条件和处理器。
2.设置变量(www.chuimin.cn)
SET语句用来设置声明的存储过程变量值。其形式如下:
如下示例展示丁声明和设置变量1nv的过程:
也可以使用SELECT.…INTO语句设置变量。例如,inv变量也可以如下设置:
当然,此变量是声明该变量的BEGIN/END块作用范围内的一个局部变量。如果希望在存储过程外使用此变量,需要将其作为OUT变量传递,如下:
得到结果如下:
不过,可能不清楚DELIMITER语句有什么用。默认地,MySQL使用分号来确定一个语句是否结束。不过,创建一个包含多个语句的存储过程时,需要编写多个语句,但在完成这个存储过程之前,并不希望MySQL执行任何操作。因此,必须把定界符修改为另一个字符串。不一定非得是//。可以选择喜欢的任何定界符,如可以|||或^^。
有关MySQL数据库设计与实现的文章
这一节将重点讨论促使MySQL风行的一些关键特性。接下来,还将提供有关MySQL产品两个主要里程碑版本的重要信息。庞大的开源社区:MySQL之所以如此流行和受欢迎,很大一部分功劳要归功于开源社区的积极支持。在开源社区中不仅能了解到MySQL的最新发展动态,还能快速地解决一些问题和难题。......
2023-10-29
在MySQL已经成功启动的前提下,输入以下命令:这样一个名为shop的数据库就创建成功了。图4.1查看系统内数据库在图4.1中,第一个数据库information_schema是MySQL自带的,该数据库存储了所有MySQL服务器管理的数据库信息,比如数据库名、数据库的表、表的数据类型及访问权限等。图4.2非法的数据库名如果要创建的数据库名字在MySQL中已经存在,也会发生错误。......
2023-10-29
由于不是所有的用户都习惯于用命令行程序,所以开发了GUI程序。下面就介绍一下SQLyog。SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库。图2.19SQLyog连接数据库进入管理界面,如图2.20所示。图2.22SQLyog查询视图结果视图,如图2.23所示。图2.23SQLyog结果视图数据库选择、常用工具栏,如图2.24所示。图2.25SQLyog菜单栏SQLyog常用技巧: Ctrl+Enter代码提示。......
2023-10-29
如下语法可用于创建存储过程:而如下语法用于创建存储函数:例如,来创建一个返回静态字符串的简单存储过程:仅此而已。请继续阅读,了解创建复杂的存储过程还有哪些选项。例如,能够使用PHP、Perl和Python语言创建存储过程,这意味着过程的功能只受所使用语言的限制。在编写本书时,此特点对存储过程的功能没有影响。......
2023-10-29
事务的隔离级别就是用来设置事务在读取数据时的隔离状态,提高数据并发使用效率的一种手段。事务的隔离级别由低到高可分为5个级别。MySQL默认级别,这种隔离级别可以避免“不可重复读取”,达到可重复读取。更改事务的隔离级别的语法代码如下:事务隔离级别的作用范围分为两种: 全局级:对所有的会话有效 会话级:只对当前的会话有效例如,设置会话级隔离级别为READ COMMITTED:或:设置全局级隔离级别为READ COMMITTED:......
2023-10-29
MySQL要求AUTO_INCREMENT属性用于作为主键的列。与之相反,忽略BINARY属性时,将使用不区分大小写的方式排序。否则,默认值将依赖于字段的数据类型。简言之,提供该属性是为了保证数据库兼容性。将不允许向该列插入NULL值。建议在重要情况下始终使用NOT NULL属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。PRIMARY KEYPRIMARY KEY属性用于确保指定行的唯一性。......
2023-10-29
图5.2交叉连接的例子2.内连接内连接将返回与连接条件相匹配的数据行。图5.3表employee和department使用内连接查询两个表中的数据,如图5.4所示。图5.6使用右外连接的例子4.自连接自连接就是将表与它自身相关联,进行自连接时通过给表起不同的别名来区分一个表的两个实例。......
2023-10-29
表示索引为唯一性索引。指索引的长度,必须是字符串类型才可以使用。如果在创建索引时没写索引名称,MySQL会自动用字段名作为索引名称。其中table_name是要增加索引的表名,column_list指出对哪些列进行索引,多列时各列之间用逗号分隔。另外,ALTER TABLE允许在单个语句中更改多个表,因此可以在同时创建多个索引。另外,不能用CREATE INDEX语句创建PRIMARY KEY索引。......
2023-10-29
相关推荐