MYSQL学习笔记——连接以及存储过程

连接

当我们需要从多个表查询数据时,我们就需要使用到连接操作,mysql支持内连接,左连接以及右连接三种连接方式。

数据库准备

首先我们创建两个表t1, t2:

create table t1(i1 int, c1 varchar(10));
create table t2(i2 int, c2 varchar(10));

  插入数据:

insert into t1 values (1, ‘a‘), (2, ‘b‘), (3, ‘c‘);
insert into t2 values (2, ‘c‘), (3, ‘b‘), (4, ‘a‘);

  最后可以查看我们的数据库表如下:

内连接

如果在SELECT语句的FROM子句中列出多个数据表,并用INNER JOIN将它们的名字隔开,MYSQL将执行内连接操作,这将通过把一个数据表里的数据行与另一个数据表里的数据行进行匹配产生结果。比如,下面的查询将把t1里的每一个数据行与t2里的每一个数据行组合:

不加任何条件的内连接将产生笛卡尔积,结果行数是两张数据表行数的乘积,例如两张表分别有1000条数据,那么结果行数将有100万条数据,所以我们在用内连接时一般会加上条件,下面的查询只会选出t1.i1=t2.i2的行,大大减少了检出行:

外连接

内连接只显示在两个数据表里都能找到匹配的数据行,外连接除了显示同样的匹配结果,还可以把其中一个数据表在另一个数据表里没有匹配的数据行也显示出来,mysql支持的外连接分左外连接(LEFT JOIN)和右外连接(RIGHT JOIN)。

LEFT JOIN的工作情况是这样的:两个数据表,以左表为基准,当来自左表的某个数据行与右表的某个数据行匹配时,那两个数据表的内容就会作为一个输出行;如果右表没有匹配行,那么也会产生输出行,此时右表的内容用NULL填充。

RIGHT JOIN与LEFT JOIN相似,只是以右表为基准,如果左表不匹配,用NULL填充。

我们用LEFT JOIN代替上例的INNER JOIN,得到的输出如下:

有时候,我们在编写左连接时,真正感兴趣的是那些左数据表里没被匹配的行,这时候我们可以用IS NULL判断条件把这些行挑选出来:

RIGHT JOIN与LEFT JOIN十分相似,而且所有RIGHT JOIN都能改写成LEFT JOIN这里就不举例了,而且就我的工作经验来看,工作中统一写LEFT JOIN更好。

存储过程                                                                                           

存储过程简单来说,就是为以后的使用而保存的一条或多条MYSQL语句的集合,可将其视为批文件,虽然它们的作用不仅限于批处理。

1、数据库准备

首先使用以下命令创建一个数据库并批量插入数据:

create table g(num int,value  varchar(10)); 

insert into g values(1, ‘1‘),(10, ‘10‘),(60, ‘60‘),(100, ‘100‘);

查看该表数据如下:

  

2、调用存储过程

在创建存储过程之前,先说一下如何调用存储过程,调用存储过程的命令如下:

call 存储过程名字();

2.1、创建封装sql存储过程

存储过程的一个作用就是封装sql,我们创建的第一个存储过程就是封装一个select语句:

DELIMITER //
CREATE PROCEDURE p1()
BEGIN
	select * from g;
END//
DELIMITER ;

"DELIMITER //"的作用是把行结束符替换为//,默认的行结束符是";"。为什么要替换行结束符呢?因为创建存储过程是一条独立语句,但是这条创建语句内部一般都会包含以";"结束的语句,如果我们不更改结束符,那么语句解析到";"就会提前结束。

以上面的语句为例,如果我们不更改行结束符,那么创建语句到"select * from g;"就会结束(因为遇到了行结束符";"),这显然不是我们想要的,但是我们更改结束符后,创建语句会一直解析到"END //",成功创建存储过程。

最后别忘了调用"DELIMITER ;"把行结束符改回来。

创建完后我们调用一下该存储过程,结果如下:

        

2.2、创建包含参数的存储过程

存储过程还可以包含参数,下面我们创建一个包含参数的存储过程 

DELIMITER //
CREATE PROCEDURE p2(IN n int, OUT avg double, INOUT min int)
BEGIN
	select avg(num) from g where num > n INTO avg;
	select min(num) from g where num > n INTO min;
END//
DELIMITER ;

注意,在参数前面包含IN,OUT,INOUT关键字,IN表示传入值,OUT表示传出值,INOUT表示即可以传入也可以传出。

最后,我们调用一下我们创建的存储过程如下:

2.3、包含控制结构的存储过程

存储过程还可以包含if-else结构,例子如下:

DELIMITER //
CREATE PROCEDURE p3(IN n int, IN switch char(1))
BEGIN
	if switch=‘a‘ then
        select * from g where num > n;
    else
	    select * from g where num > n;
	end if;
END//
DELIMITER ;

  调用该存储过程的结果如下:

2.4、包含循环的存储过程

除了包含if-else结构,存储过程还可以包含while循环结构,举例如下:

DELIMITER //
CREATE PROCEDURE p4(IN n int)
BEGIN
	declare i int;
	declare s int;
	set i = 1;
	set s = 0;
	while i <= n do
	    set s = s + i;
	    set i = i + 1;
	end while;
	select s;
END//
DELIMITER ;

  该存储过程将计算从1到n的累加,调用该存储过程的例子如下:

3、查看现有的存储过程

如果想知道数据库有哪些存储过程,我们可以使用以下命令查看:

show procedure status

4、删除存储过程

如果想要删除存储过程,我们可以使用如下命令:

drop procedure 存储过程的名字

5、查看存储过程的创建语句

有的时候我们想要查看存储过程的创建语句那么我们可以使用以下命令:

show create procedure 存储过程的名字

6、存储过程与存储函数  

  在mysql中除了存储过程,还有存储函数,存储过程与存储函数的区别有两点:

1、创建语句不一样,存储过程使用命令"CREATE PROCEDURE"创建,存储函数使用命令"CREATE FUNCTION"创建;

2、存储过程没有返回值,而函数有返回值。

时间: 2024-10-19 03:18:05

MYSQL学习笔记——连接以及存储过程的相关文章

MySQL学习笔记九:存储过程,存储函数,触发器

存储过程 1.存储过程由一组特定功能的SQL语句组成,对于大型应用程序优势较大,相对不使用存储过程,具有以下优点: a.性能提高,因为存储过程是预编译的,只需编译一次,以后调用就不须再编译 b.重用性提高,可以“一次编写,随便调用” c.安全性提高,可以一定程度上防止SQL注入,还可以使用权限控制 d.减少网络流量,提高网站访问速度 2.存储过程的建立,使用create procedure语句,语法如下 CREATE [DEFINER = { user | CURRENT_USER }] PRO

MySQL学习笔记-子查询和连接

MySQL学习笔记-子查询和连接 使客户端进入gbk编码方式显示: mysql> SET NAMES gbk; 1.子查询 子查询的定义: 子查询(Subquery)是指出现在其他SQL语句内的SELECT子句. 例如:  SELECT * FROM t1 WHERE col1 = (SELECT col2 FROM t2); 其中SELECT * FROM t1 称为Outer Query / Outer Statement (外部查询) SELECT col2 FROM t2 , 被称为Su

Mysql学习笔记(十一)临时表+视图

原文:Mysql学习笔记(十一)临时表+视图 学习内容: 临时表和视图的基本操作... 临时表与视图的使用范围... 1.临时表   临时表:临时表,想必大家都知道这个概念的存在...但是我们什么时候应该使用到临时表呢?当一个数据库存在着大量的数据的时候,我们想要获取到这个数据集合的一个子集,那么我们就可以使用临时表来保存我们想要的数据..然后对临时表进行操作就可以了...使用临时表必然是有原因的..使用临时表会加快数据库的查询性能.... create temporary table tmp_

MySql学习笔记(转载)

/* 启动MySQL */net start mysql /* 连接与断开服务器 */mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限验证登录MySQL */mysqld --skip-grant-tables-- 修改root密码密码加密函数password()update mysql.user set password=password('root'); SHOW PROCESSLIST -- 显示哪些线程正在运行SHOW VARIABLES -- /* 数据库操

MySQL学习笔记-安装和基本操作

MySQL学习笔记-安装和基本操作   1.安装MySQL 1 # yum -y install mysql mysql-server mysql-devel 添加/etc/my.conf配置: 1 vi /etc/my.conf2 [mysqld]3 default-character-set=utf84 character_set_server=utf85 [client]6 default-character-set=utf8 2.启动和停止MySQL服务: # service mysql

MySQL学习笔记之一 MySQL入门

本人之前接触的关系型数据库主要是oracle和sqlserver,而对于mysql知之甚少,但查阅网上资料发现,mysql与oracle非常相似,所以学起来应该不会很费劲,在总结的时候可能更多的把关注点放在它与oracle的不同之处. 一.简介 MySQL是一个真正的多用户.多线程SQL数据库服务器.SQL(结构化查询语言)是世界上最流行的和标准化的数据库语言.MySQL是一个客户端/服务器结构的实现, 它由一个服务器守护程序mysqld和很多不同的客户程序和库组成. MySQL的普及并不局限于

MySQL学习笔记—SQL服务器模式汇总

MySQL学习笔记-SQL服务器模式汇总 MySQL服务器可以以不同的SQL模式来操作,并且可以为不同客户端应用不同模式.这样每个应用程序可以根据自己的需求来定制服务器的操作模式. 模式定义MySQL应支持哪些SQL语法,以及应执行哪种数据验证检查.这样可以更容易地在不同的环境中使用MySQL,并结合其它数据库服务器使用MySQL. 你可以用–sql-mode="modes"选项启动mysqld来设置默认SQL模式.如果你想要重设,该值还可以为空(–sql-mode ="&q

MySQL学习笔记之三 表类型

你能用的数据库引擎取决于MySQL在安装时候是如何被编译的.要添加一个新的引擎,就必须编译MySQL.仅仅为了添加一个特性而编译应用程序的想法对于Windows的开发人员来说可能有点小题大做,得不偿失,但是在Unix的世界里,这已经成为了标准.在缺省的情况下,MySQL支持三个引擎:ISAM.MyISAM和HEAP.另外两种类型InnoDB和Berkley(BDB),也常常可以使用. ISAM ISAM是一个定义明确且历经时间考验的数据表格管理方法,它在设计之初就考虑到数据库被查询的次数远远大于

MySQL学习笔记—触发程序

MySQL学习笔记-触发程序 触发程序是与表有关的命名数据库对象,当表上发生特定事件时,将触发执行相应的触发程序. CREATE TRIGGER语法 CREATE TRIGGER语法: CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH ROW trigger_stmt 触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象. 触发程序与命名为tbl_name的表相关.tbl_na