最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL存储结构的使用_MySQL

来源:动视网 责编:小采 时间:2020-11-09 17:00:51
文档

MySQL存储结构的使用_MySQL

MySQL存储结构的使用_MySQL:前言: 今天公司老大让我做一个MySQL的调研工作,是关于MySQL的存储结构的使用。这里我会通过3个例子来介绍一下MySQL中存储结构的使用过程,以及一些需要注意的点。 笔者环境: 系统:Windows 7 MySQL:MySQL 5.0.96 准备工作: 1.新建两张数据表:s
推荐度:
导读MySQL存储结构的使用_MySQL:前言: 今天公司老大让我做一个MySQL的调研工作,是关于MySQL的存储结构的使用。这里我会通过3个例子来介绍一下MySQL中存储结构的使用过程,以及一些需要注意的点。 笔者环境: 系统:Windows 7 MySQL:MySQL 5.0.96 准备工作: 1.新建两张数据表:s


前言:

今天公司老大让我做一个MySQL的调研工作,是关于MySQL的存储结构的使用。这里我会通过3个例子来介绍一下MySQL中存储结构的使用过程,以及一些需要注意的点。

笔者环境:

系统:Windows 7

MySQL:MySQL 5.0.96

准备工作:

1.新建两张数据表:student1, student2

新建student1

DROP TABLE IF EXISTS student1;
CREATE TABLE student1 (
id INT NOT NULL auto_increment,
name TEXT,
age INT,
PRIMARY KEY(id)
);

新建student2
DROP TABLE IF EXISTS student2;
CREATE TABLE student2 (
id INT NOT NULL auto_increment,
name TEXT,
age INT,
PRIMARY KEY(id)
);

2.向student1中新增数据

INSERT INTO student1 (name, age) VALUES ('xiaoming', 18);
INSERT INTO student1 (name, age) VALUES ('xiaohong', 17);
INSERT INTO student1 (name, age) VALUES ('xiaogang', 19);
INSERT INTO student1 (name, age) VALUES ('xiaoyu', 18);
INSERT INTO student1 (name, age) VALUES ('xiaohua', 20);

实现功能说明:

1.打印student1中的部分信息
2.把student1中的部分数据复制到student2中
3.传入参数作为条件,把student1中的部分数据复制到student2中

注意事项:

在编写存储结构的时候,我们不能以分号(;)结束。因为我们的SQL语句就是以分号(;)结尾的。这里我们要修改一下存储结构的结束符号(&&)。

这里我们使用MySQL中的DELIMITER进行修改,并在存储结构创建完毕时,再改为分号(;)结束即可。

关于这一点在后面的例子中有所体现。在编写MySQL的触发器中,也会用到类似的情况。

使用方式:

1.打印student1中的部分信息

---------------------------------------------------------------
DROP PROCEDURE IF EXISTS test_pro1;
---------------------------------------------------------------
DELIMITER &&
CREATE PROCEDURE test_pro1()
BEGIN
 set @sentence = 'select * from student1 where age<19;';
 prepare stmt from @sentence;
 execute stmt;
 deallocate prepare stmt;
END &&
DELIMITER ;

2.复制表存储过程的编写(不带参数)

---------------------------------------------------------------
DROP PROCEDURE IF EXISTS test_pro2;
---------------------------------------------------------------
DELIMITER &&
create procedure test_pro2()
begin
 DECLARE stop_flag INT DEFAULT 0;
 DECLARE s_name TEXT default '';
 DECLARE s_age INT default 0;
 
 DECLARE cur1 CURSOR FOR (select name, age from student1 where age<19);
 DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET stop_flag=1;
 open cur1;
 fetch cur1 into s_name, s_age;
 while stop_flag<>1 DO
 insert into student2(name, age) values(s_name, s_age);
 fetch cur1 into s_name, s_age;
 end while;
 close cur1;
end &&
DELIMITER ;

3.复制表存储过程的编写(带参数)

---------------------------------------------------------------
DROP PROCEDURE IF EXISTS test_pro3;
---------------------------------------------------------------
DELIMITER &&
create procedure test_pro3(IN p_age INT)
begin
 DECLARE stop_flag INT DEFAULT 0;
 DECLARE s_name TEXT default '';
 DECLARE s_age INT default 0;
 
 DECLARE cur1 CURSOR FOR (select name, age from student1 where age1 DO
 insert into student2(name, age) values(s_name, s_age);
 fetch cur1 into s_name, s_age;
 end while;
 close cur1;
end &&
DELIMITER ;

4.使用方式:

call test_pro1();
or
call test_pro1(123);

文档

MySQL存储结构的使用_MySQL

MySQL存储结构的使用_MySQL:前言: 今天公司老大让我做一个MySQL的调研工作,是关于MySQL的存储结构的使用。这里我会通过3个例子来介绍一下MySQL中存储结构的使用过程,以及一些需要注意的点。 笔者环境: 系统:Windows 7 MySQL:MySQL 5.0.96 准备工作: 1.新建两张数据表:s
推荐度:
标签: 保存 存储 mysql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top