mysql数据库具有开源,跨平台性,免费使用, 功能强大且使用方便等众多优点。了解它的语法是很有必要的。那么咱们现在就来学习一下它的语法结构。
一:
创建数据库:
create {database | schema} [if not exists] 库名 [default] character set [=] charset_name
if not exists 如果存在,就忽略。
character set 默认字符集编码。
创建数据库: create database
修改数据库: alter database
删除数据库: drop database
1、mysql常见的数据类型;
数据类型是指列、存储过程参数、表达式和局部变量的数据特征,它决定了数据的存储格式,代表了不同的信息类型。
整型:
数据类型 字节
tinyint 1
smallint 2
mediumint 3
int 4
bigint 8
浮点型:
float[(M,D)] M是数字总位数,D是小数点后面的位数。
如果M和D被省略,根据硬件允许的限制来保存值。单精度浮点数。
double[(M,D)]
日期时间型:
date 3字节 YYY-MMM-DD 日期值
time 3字节 HH:MM:SS 时间值
year 1字节 YYYY 年份值
datetime 8字节 YYYY-MM-DD 混合日期和时间值
timestamp 8字节 YYYYMMDDHHMMSS 混合日期和时间值,时间戳。
字符型:
char 0-255字节 定长字符串
varchar 0-65535字节 变长字符串
tinytext 短文本字符串
text 长文本数据
mediumtext 中等长度文本数据
longtext 极大文本数据
enum('value1','value2') 1或2个字节
取决于枚举值的个数(最多65535个数).
set(‘value1','value2') , 1、2、3、4或8个字节,取决于set成员的数目u(最多64个成员)
打开数据库:use 库名;
验证用户打开的数据库:
select database();
创建数据表:
create table [if not exists] 表名(列名称 数据类型,...)
查看数据表列表
show tables [from 库名] [like 'pattern' | where expr]
查看数据表结构:
show columns from 表名; 或 desc 表名
插入记录:
insert [into] 表名 [(字段名,...)] values(值,...);
insert 表名 values(值,...)
查找记录
select 字段,........ from 表名;
mysql空值和非空:
空值与非空值
NULL: 表示字段可以为空
NOT NULL:表示字段不允许为空。
mysql自动编号:
自动编号,且必须和主键组合使用
默认情况下,起始值为1,每次增量为1. auto_increment
mysql主键约束:
primary key或key
主键约束特点:
每张数据表只能存在一个主键,
主键保证记录的唯一性。
主键自动为not null
mysql唯一约束:
unique key
唯一约束特点:
唯一约束可以保证记录的唯一性
唯一约束的字段可以为空值(null)
每张数据表可以存在多个唯一约束。
mysql默认约束:
default
默认值
当插入记录时,如果没有明确为字段赋值,则自动赋予默认值。
总结:
数字类型: 字符型,整型,浮点型, 日期时间型
数据表操作: 插入记录,查找记录。
记录操作: 创建数据表,约束的使用。
二:
数据表操作:
如何创建数据表:
主键约束(primary key)
唯一约束(unique key)
默认约束(default)
非空约束(not null)
记录插入
记录查找
约束:
约束保证数据的完整性和一致性
约束分为表级约束和列级约束
约束类型包括:
主键约束(primary key)
唯一约束(unique key)
默认约束(default)
非空约束(not null)
外键约束(foreign key)
外键约束(foreign key)
保证数据一致性,完整性
实现一对一或一对多关系
外键约束的要求:
1、父表和子表必须使用相同的存储引擎,而且禁止使用临时表。
2、数据表的存储引擎只能为INNODB。
3、外键列和参照列必须具有相似的数据类型。其中,数字的长度或是否有符号位必须相同,而字符的长度则可以不同。
4、外键列和参照列必须创建索引。如果外键列不存在索引的话,mysql将自动创建索引。
编辑数据表的默认存储引擎:
mysql配置文件
Default-storage-engine=INNODB
查看表名所使用的引擎或表详细结构: show create table 表名;
查看表的索引: show indexes from 表名\G
查看mysql下所有数据库: show databases;
查看当前库下所有的表: show tables;
查看视图基本信息: desc 视图名;
查看视图基本信息: show table status like '视图名';
查看视图详细信息: show create view 视图名
查询所有触发器的信息: show triggers
查询指定触发器的详细信息:
select * from information_schema.triggers where trigger_name='触发器名';
查看存储过程和函数的状态:
show {查询存储过程 | 查询存储函数} status [like 'pattern'];
注意: like 'pattern' : 匹配存储过程或函数名称。
查看存储过程和函数状态:
show create {procedure | function} sp_name;
procedure : 表示查询存储过程。
function : 表示查询存储函数。
sp_name : 表示存储过程或函数名。
select * from information_schema.Routines WHERE routine_name='sp_name';
注意: routine_name : 存储过程和函数名。
sp_name 存储过程或函数名。
mysql 外键约束的参照操作:
1、cascade:从父表删除或更新且自动删除或更新子表中匹配的行。
2、set null:从父表删除或更新行,并设置子表中的外键列为null.如果使用该选项,必须保证子表列没有指定not null.
3、resttict:拒绝对父表的删除或更新操作。
4、no action: 标准SQL的关键字,在mysql中restrict相同。
mysql表级约束和列级约束
列级约束:指对一个数据列建立的约束
表级约束:指对多个数据列建立的约束。
列级约束既可以在列定义时声明,也可以在列定义后声明。
表级约束只能在列定义后声明。
mysql修改数据表--添加删除列
修改数据表
添加单列:
alter table 表名 add [column] 列名 列定义 [first | after 列名]
列名(col_name)
列定义(column_definition)
添加多列:
alter table 表名 add [column] (列名 列定义,...)
删除列:
alter table 表名 drop [列] 列名
添加主键约束:
alter table 表名 add [constraint [symbol]] primary key [index_type](index_col_name)
例如:
mysql> create table user2(
-> username varchar(10) not null,
-> pid smallint unsigned
-> );
Query OK, 0 rows affected (0.02 sec)
mysql> desc user2;
mysql> alter table user2 add id smallint unsigned;
mysql> alter table user2 add constraint pk_user2_id primary key(id);
添加唯一约束:
alter table 表名 add [constraint [symbol]] unique [index | key] [index_name] [index_type] (index_col_name,....)
例:
mysql> alter table user2 add unique(username);
mysql> desc user2;
mysql> alter table user2 add foreign key(pid) references provinces(id);
添加/删除默认约束
alter table 表名 alter [column] col_name {set default literal | drop default}
例:
mysql> alter table user2 add age tinyint unsigned not null;
mysql> alter table user2 alter age set default 15;
mysql修改数据表---删除约束
删除主键约束
alter table 表名 drop primary key
例:
mysql> alter table user2 drop primary key;
mysql> desc user2;
删除唯一约束:
alter table 表名 drop {index|key} index_name
例:
mysql> alter table user2 drop index username;
删除外键约束:
alter table 表名 drop foreign key fk_symbol(外键约束名称)
例如:
mysql> show create table user2;
mysql> alter table user2 drop foreign key user2_ibfk_1;
mysql> alter table user2 drop index pid;
mysql修改数据表---修改列定义和更名数据表
修改列定义:
alter table 表名 modify [column]
col_name col_definition [first | after col_name]
例如:
mysql> alter table user2 modify id smallint unsigned not null first;
mysql> show columns from user2;
mysql> alter table user2 modify id tinyint unsigned not null;
修改列名称
alter table 表名 change [column] old_col_name new_col_name col_definition [first | after col_name]
例如:
mysql> desc user2;
mysql> alter table user2 change pid p_id tinyint unsigned not null;
mysql> desc user2;
数据表更名:
方法一:
alter table 表名 rename [to|as] new_tb1_name
方法二:
rename table 表名 to 新表名 [,表名2 to 新表名2]...
例如:
mysql> alter table user2 rename user3;
或:
mysql> rename table user3 to user2;
总结:
一、约束:
(1)按功能划分:not null,primary key,unique key, default, foreign key
(2) 按数据列的数目划分:表级约束,列级约束。
二、修改数据表;
(1)针对字段的操作:添加/删除字段,修改列定义,修改列名称等。
(2)针对约束的操作:添加/删除各种约束。
(3)针对数据表的操作:数据表更名(两种方式)
mysql 插入记录insert
插入记录:
insert [into] 表名 [(col_name,...)]
{values | value} {{expr | default},...),(...),....}
例如:
mysql> create table user(
-> id smallint unsigned primary key auto_increment,
-> username varchar(20) not null,
-> password varchar(30) not null,
-> age tinyint unsigned not null default 10,
-> sex boolean
-> );
mysql> insert user values(null,'Tom','123',24,1);
mysql> insert user values(null,'join','456',25,1);
mysql> insert user values(default,'Tom','456',26,0);
mysql> insert user values(default,'join','123',2*8+3,0),(null,'jack','5678',default,0);
插入记录:
insert [into] 表名 set col_name={expr | default}...
例如:
mysql> insert user set username='jack',password='123.cn';
插入记录:
insert [into] 表名 [(col_name,...)] select ...
mysql单表更新update和删除记录delete
update
更新记录(单表更新)
update [low_priority] [ignore] table_reference set col_name1={expr1 | default} [,col_name2={expr2 | default}]... [where where_condition]
例如:
mysql> update user set age=age+5;
mysql> update user set age=age-id,sex=0;
mysql> update user set age=age+5 where id%2=0;
delete
删除记录(单表删除)
delete from 表名 [where 搜索条件]
例如:
mysql> delete from user where id=3;
mysql> insert user values(null,'111','456','30',null);
select
查找记录
select select_expr [.select_expr..]
[
from table_references
[where 条件表达式]
[group by {col_name | position} [asc | desc],...]
[having 条件表达式]
[order by {col_name | expr | position } [asc | desc],...]
[limit {[offset]row_count | row_count offset offset}]
]
查询表达式
查询表达式表示你想要的某一列,必须至少有一列
多个列之间用英文逗号分隔。
星号(*)表示所有列,tbl_name.*可以表示命名表的所有列
查询表达式可以使用[AS]alias_name为其赋予别名。
别名可以用于group by,order by 或having子句。
where
条件表达式:
对记录进行过滤,如果没有指定where子句,则显示所有记录。
在where表达式中,可以使用mysql支持的函数或运算符。
group by
查询结果分组
[group by {col_name | position} [asc | desc ],...]
例如:
mysql> select sex from user group by sex;
having
分组条件
[having 分组条件]
例如:
mysql> select age from user group by age having age>300;
mysql> select sex,age from user group by 1 having count(id)>=2;
order by
对查询结果进行排序
[order by {col_name | expr |position } [asc | desc],....]
例如:
mysql> insert user values(null,'123','234','30',1);
mysql> select * from user order by id asc;
mysql> select * from user order by age,id desc;
limit
限制查询结果返回的数量
[LIMIT {[offset,]row_count | row_count OFFSET offset}]
例如:
mysql> select * from user limit 2,2;
mysql> select * from user limit 3;
mysql> create table test(
-> id tinyint unsigned primary key auto_increment,
-> username varchar(20)
-> );
mysql> insert test(username) select username from user where age >=30;
mysql> select * from test;
mysql三种常见的子查询:
用any,some或all修饰的比较运算符:
operand comparison_operator any(subquery)
operand comparison_operator some(subquery)
operand comparison_operator all(subquery)
any,some,all关键字
运算符 any some all
>,>= 最小值 最小值 最大值
<,<= 最大值 最大值 最小值
= 任意值 任意值
<>,!= 任意值
例如:
mysql> select goods_id,goods_name,goods_price from tdb_goods where goods_price>any(select goods_price from tdb_goods where goods_cate='超级本');
使用[not] in的子查询
语法:
operand comparison_operator [not] in (subquery)
=any 运算符与in等效
!=all 或<>all运算与not in等效。
例如:
创建商品分类:
mysql> create table if not exists tdb_goods_cates(
-> cate_id smallint unsigned primary key auto_increment,
-> cate_name varchar(40) not null
-> );
mysql> select goods_cate from tdb_goods group by goods_cate;
将这个插入到tdb_goods_cates
mysql> desc tdb_goods_cates;
mysql> insert tdb_goods_cates(cate_name) select goods_cate from tdb_goods group by goods_cate;
mysql> select * from tdb_goods_cates;
mysql多表更新
多表更新
update table_references
set col_name1(列)={表达式1 | default}
[,col_name2={表达式2 | default}]..
[where where_condition]
表的参照关系:
table_reference
{[inner内 | cross] join | {left|right} [outer] join}
table_reference
on conditional_expr 表的连接条件
连接类型:
inner join,内连接
在mysql中,join,cross join和inner join是等价的。
left [outer] join,左外连接。
right [outer] join,右外连接。
例如:
mysql> update tdb_goods inner join tdb_goods_cates on goods_cate=cate_name set goods_cate=cate_id;
create...select
创建数据表同时将查询结果写入到数据表
create table [if not exists] 表名
[(create_definition,....)]
select_statement
例如:
mysql> select brand_name from tdb_goods group by brand_name;
mysql> create table tdb_goods_brands(
-> brand_id smallint unsigned primary key auto_increment,
-> brand_name varchar(40) not null
-> )
-> select brand_name from tdb_goods group by brand_name;
mysql> select * from tdb_goods_brands;
mysql> update tdb_goods AS a inner join tdb_goods_brands AS b on a.brand_name=b.brand_name set a.brand_name=b.brand_id;
mysql> desc tdb_goods\G;
需要修改字段名和字段类型:
mysql> alter table tdb_goods
-> change goods_cate cate_id smallint unsigned not null,
-> change brand_name brand_id smallint unsigned not null;
mysql> insert tdb_goods_cates(cate_name) values
-> ('路由器'),('交换机'),('网卡');
mysql> insert tdb_goods_brands(brand_name)values('海尔'),('清华同方'),('神舟');
mysql> insert tdb_goods(goods_name,cate_id,brand_id,goods_price)values('yuan 123.cn密码集合','13','4','1849');
mysql内连接inner join
子查询与连接:
连接
mysql的select语句,多表更新,多表删除语句中支持join操作。
语法结构;
table_reference
{[inner |cross] join | {left | right} [outer] join}
table_reference
on conditional_expr 连接条件。
数据表参照:
table_reference
表名 [[as] alias] | table_subquery [as] alias
数据表可以使用:表名 AS 别名 或表名 别名 赋予别名
table_subquery可以作为子查询使用在from子句中,这样的子查询必须为其赋予别名。
连接类型:
inner join, 内连接
在mysql中,join,cross join和inner join是等价的。
left [outer] join,左外连接。
right [outer] join,右外连接。
连接条件:
使用on关键字来设定连接条件,也可以使用where来代替。
通常使用on关键字来设定连接条件。
使用where关键字来进行结果集记录的过滤。
内连接
显示左表和右表符合连接条件的记录。
例如:
mysql> select goods_id,goods_name,cate_name from tdb_goods inner join tdb_goods_cates on tdb_goods.cate_id=tdb_goods_cates.cate_id;
mysql外连接outer join
左外连接
显示左表的全部记录及右表符合连接条件的记录
右外连接
显示右表的全部记录及左表符合连接条件的记录。
左外连接:
例如:
mysql> select goods_id,goods_name,cate_name from tdb_goods left join tdb_goods_cates on tdb_goods.cate_id=tdb_goods_cates.cate_id;
右外连接:
mysql> select goods_id,goods_name,cate_name from tdb_goods right join tdb_goods_cates on tdb_goods.cate_id=tdb_goods_cates.cate_id\G;
mysql多表连接:
例如:
mysql> select goods_id,goods_name,cate_name,brand_name,goods_price from tdb_goods AS a inner join tdb_goods_cates AS b ON a.cate_id=b.cate_id
-> inner join tdb_goods_brands AS c ON a.brand_id=c.brand_id\G;
外连接:
A LEFT JOIN B join_condition
数据表B的结果集依赖数据表A
数据表A的结果集根据左连接条件依赖所有数据表(B表除外)
左外连接条件决定如何检索数据表B(在没有指定where条件的情况下)
如果数据表A的某条记录符合where条件,但是在数据表B中不存在符合连接条件的记录,将生成一个所有列为空的额外的B行。
外连接:
如果使用内连接查找的记录在连接数据表中不存在,并且在where子句中尝试以下操作:col_name is null时,如果col_name被定义为not null, mysql将在找到符合连接条件的记录后停止搜索更多的行。
mysql无限级分类表设计:
无限级分类数据表的设计
例如:
mysql> create table tdb_goods_types(
-> type_id smallint unsigned primary key
-> auto_increment,
-> type_name varchar(20) not null,
-> parent_id smallint unsigned not null default 0);
parent_id 父类的ID。
mysql> select * from tdb_goods_types;
例如:
mysql> select s.type_id,s.type_name,p.type_name from tdb_goods_types AS s LEFT JOIN tdb_goods_types AS p ON s.parent_id=p.type_id;
mysql> select p.type_id,p.type_name,s.type_name from tdb_goods_types AS p LEFT JOIN tdb_goods_types AS s ON s.parent_id=p.type_id;
mysql> select p.type_id,p.type_name,s.type_name from tdb_goods_types AS p LEFT JOIN tdb_goods_types AS s ON s.parent_id=p.type_id GROUP BY p.type_name;
mysql> select p.type_id,p.type_name,s.type_name from tdb_goods_types AS p LEFT JOIN tdb_goods_types AS s ON s.parent_id=p.type_id GROUP BY p.type_name ORDER BY p.type_id;
mysql> select p.type_id,p.type_name,count(s.type_name) child_count from tdb_goods_types AS p LEFT JOIN tdb_goods_types AS s ON s.parent_id=p.type_id GROUP BY p.type_name ORDER BY p.type_id;
mysql多表删除:
例如:
mysql> select goods_id,goods_name from tdb_goods group by goods_name;
mysql> select goods_id,goods_name from tdb_goods group by goods_name HAVING count(goods_name)>1;
mysql> DELETE t1 from tdb_goods AS t1 LEFT JOIN (SELECT goods_id,goods_name from tdb_goods GROUP BY goods_name HAVING count(goods_name)>1) AS t2 ON t1.goods_name=t2.goods_name WHERE t1.goods_id>t2.goods_id;
mysql> select * from tdb_goods\G
mysql字符函数:
运算符和函数
根据功能的不同可以划分为:
1、字符函数
2、数值运算符与函数
3、比较运算与函数
4、日期时间函数
5、信息函数
6、聚合函数
7、加密函数
字符函数:
函数名
CONCAT( ) : 字符连接
CONCAT_WS( ) : 使用指定分隔符进行字符连接。
FORMAT( ) : 数字格式化
LOWER( ) : 转换成小写字母
UPPER( ) : 转换成大写字母
LEFT( ) : 获取左侧字符。
RIGHT( ) : 获取右侧字符。
例如:
mysql> select * from test;
mysql> select concat('yuan','_','MYSQL');
mysql> select * from user;
将两个字段合并为一个字段。
mysql> select concat(username,age) as fullname from user;
mysql> select concat('dajiangtai','_','Mysql');
mysql> select concat_ws('@','a','b','c');
mysql> select format(12345.678,2);
mysql> select lower('ANXIAOYU');
mysql> select upper('anxiaoyu');
mysql> select left('DaJiangTai',3);
mysql> select lower(left('DaJiangTai',3));
mysql> select length('dajiangtai');
length() : 获取字符串长度。
ltrim() : 删除前导空格。
rtrim() : 删除后续空格。
trim() : 删除前导和后续空格。
substring() : 字符串截取。
[not] like : 模式匹配。
replace() : 字符串替换。
例如:
mysql> select ltrim(' dajiangtai ');
mysql> select length(ltrim(' dajiangtai '));
mysql> select trim(leading '@' from '@@@dajiangtai@@@@');
mysql> select trim(trailing '@' from '@@@dajiangtai@@@@');
mysql> select trim(both '@' from '@@@dajiangtai@@@@');
mysql> select replace('@@@dajiang@@tai@@@','@','');
mysql> select replace('@@@dajiang@@tai@@@','@','##');
mysql> select substring('dajiangtai',3,5);
mysql> select substring('dajiangtai',3);
mysql> select substring('dajiangtai',-3);
mysql> select 'dajiangtai' like 'd%';
mysql 数值运算符和函数
ceil() : 进一取整
div : 整数除法
floor() : 舍一取整
mod : 取余数(取模)
power() : 幂运算。
round() : 四舍五入
truncate() : 数字截取
例如:
mysql> select 1+2;
mysql> select ceil(3.14);
mysql> select floor(3.14);
mysql> select 1/2;
mysql> select 1 div 2;
mysql> select 4%3;
mysql> select 4 mod 3;
mysql> select 4.2 mod 3;
mysql> select power(2,3);
mysql> select round(3.1415,3);
mysql> select truncate(12.3456,2);
mysql> select truncate(12.3456,-1);
mysql比较运算符和函数
[not] between...and... : [不] 在范围之内
[not] in() : [不] 在列出值范围内。
is [not] null : [不]为空。
例如;
mysql> select 2 between 1 and 3;
mysql> select 1 between 2 and 3;
mysql> select 2 between 2 and 3;
mysql> select 1 in (1,2,3,4);
mysql> select null is null;
mysql> select '' is null;
mysql日期时间函数
日期时间函数:
now() : 当前日期和时间
curdate() : 当前日期
curtime() : 当前时间
date_add() : 日期变化。
datediff() : 日期差值。
date_format() :日期格式化。
例如:
mysql> select now();
mysql> select curdate();
mysql> select date_add('2015-1-1',interval 365 day);
mysql> select date_add('2015-1-1',interval -365 day);
mysql> select datediff('2015-1-2','2015-2-2');
mysql> select date_format('2015-5-5','%m/%d/%y');
mysql 信息函数
connection_id() : 连接ID
database() : 当前数据库
last_insert_id() : 最后插入记录的ID号。
user() : 当前用户
version() : 版本信息。
例如:
mysql> select connection_id();
mysql> select database();
mysql> create table test(
-> id tinyint(3) unsigned not null primary key auto_increment,
-> username varchar(20) not null);
mysql> select last_insert_id();
mysql> insert test(username) values('join');
mysql> insert test(username) values('111');
mysql> insert test(username) values('123');
mysql> insert test(username) values('11');
mysql> insert test(username) values('22'),('33');
mysql> select last_insert_id();
mysql> select user();
mysql> select version();
mysql 聚合函数:
avg() : 平均值
count() : 计数。
max() :最大值。
min() : 最小值。
sum() : 求和。
例如:
mysql> select avg(id) from test;
mysql> select count(id) from test;
mysql 加密函数:
MD5() : 信息摘要算法
PASSWORD() : 密码算法
例如:
mysql> select md5('admin');
mysql> select PASSWORD('admin');
mysql> set PASSWORD=PASSWORD('root');
mysql自定义函数:
用户自定义函数(UDF) 是一种对mysql扩展的途径,其用法与内置函数相同。
自定义函数的两个必要条件:
(1), 参数
(2), 返回值。
函数可以返回任意类型的值,同样可以接收这些类型的参数。
创建自定义函数:
create function function_name
returns
{string | integer | real | decimal}
routine_body
关于函数体:
(1) 函数体由合法的SQL语句构成。
(2) 函数体可以是简单的select或insert语句。
(3) 函数体如果为复合结构则使用begin....end语句。
(4) 复合结构可以包含声明,循环,控制语句。
设置客户端编码为gbk :
mysql> set names gbk;
mysql> select date_format(now(),'%Y年%m月%d日 %H点: %i分: %s秒');
mysql> create function f1()
-> returns varchar(30)
-> return date_format(now(),'%Y年%m月%d日 %H点: %i分: %s秒');
mysql> CREATE FUNCTION Q1(num1 SMALLINT UNSIGNED,num2 SMALLINT UNSIGNED)
-> RETURNS FLOAT(10,2) UNSIGNED
-> RETURN (num1*num2)/2;
mysql> select Q1(3,4);
mysql> create function adduser(username VARCHAR(20))
-> RETURNS INT UNSIGNED
-> BEGIN
-> INSERT test(username) values(username);
-> RETURN LAST_INSERT_ID();
-> END
-> //
mysql> select adduser('hello');
-> //
删除函数:
DROP FUNCTION [IF EXISTS] function_name
mysql存储过程:
SQL命令----> mysql引擎---》语法分析----》 可执行命令---》执行结果----》 客户端。
存储过程:
存储过程是SQL语句和控制语句的预编译集合,以一个名称存储并作为一个单元处理。
存储过程优点:
增强了SQL语句的功能和灵活性。
实现较快的执行速度。
减少网络流量。
创建存储过程的语法:
create
[DEFINER={USER | CURRENT_USER}]
PROCEDURE sp_name ([proc_parameter[,...]])
[characteristic ...] routine_body
proc_parameter:
[IN | OUT | INOUT ] param_name type
参数:
IN : 表示该参数的值必须在调用存储过程中指定。
OUT : 表示该参数的值可以被存储过程改变,并且可以返回。
INOUT : 表示该参数在调用时指定,并且可以被改变和返回。
过程体:
过程体由合法的SQL语句构成。
过程体可以是"任意"的SQL语句。
过程体如果为复合结构则使用BEGIN...END语句。
复合结构可以包含声明,循环,控制结构。
例如:
mysql> create procedure sp1() select VERSION();
mysql> CALL sp1;
调用存储过程:
CALL sp_name([parameter[,...]])
CALL sp_name[( )]
mysql创建带有IN类型参数的存储过程:
例如:
mysql> delimiter //
mysql>
mysql> create procedure removeTestByid(IN id INT unsigned)
-> BEGIN
-> DELETE FROM test where id=id;
-> END
-> //
修改存储过程:
alter procedure sp_name
[characteristic ...]
COMMENT 'string'
| {CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL
DATA}
| SQL SECURITY {DEFINER | INVOKER}
删除存储过程:
drop procedure 名字;
例如:
mysql> insert user(username,password,age,sex) values('Tom1','123',21,1),('Tom2',
'1234',22,1);
mysql> insert user(username,password,age,sex) values('Tom3','123',30,1),('Tom4',
'1234',30,1);
mysql> insert user(username,password,age,sex) values('Tom5','12',20,1),('Tom6','
1234',32,1);
mysql> delimiter //
mysql> create procedure removeUserByid(IN p_id INT UNSIGNED)
-> BEGIN
-> DELETE FROM user where id=p_id;
-> END
-> //
mysql> delimiter ;
mysql> CALL removeUserByid(2);
mysql> SELECT * FROM user where id=2;