1.描述表得结构
desc table_name;
1
1
1
desc table_name;
2.删除表中得数据
delete from table_name where [约束条件]
1
1
1
delete from table_name where [约束条件]
3.可变浮点数定义用decimal(n,m)
n :是浮点数的(二进制)位数
m:是小数分的位数
eg:decimal(10,2)
3
3
1
n :是浮点数的(二进制)位数
2
m:是小数分的位数
3
eg:decimal(10,2)
4.标准的存储过程模板如下:
drop procedure if exists pro_1;
delimiter $
create procedure pro_1(
)
begin
end $
delimiter ;
9
9
1
drop procedure if exists pro_1;
2
delimiter $
3
create procedure pro_1(
4
5
6
)
7
begin
8
end $
9
delimiter ;
<1>.设置变量
set @var_name = 0,@var_id = 12;
select @var_name , @var_id;
2
2
1
set @var_name = 0,@var_id = 12;
2
select @var_name , @var_id;
<2>.流程控制
select username,
case username
when 'belong' then 'handsome'
when 'tom' then 'sou'
else 'ban'
end
from user;
7
7
1
select username,
2
case username
3
when 'belong' then 'handsome'
4
when 'tom' then 'sou'
5
else 'ban'
6
end
7
from user;
红色部分就是查询的第二个字段
<3>.if
select * ,if(id>4,'男','女') sex from user;
1
1
1
select * ,if(id>4,'男','女') sex from user;
重命名可以省略 as 因为查询的值都在select 与from之间
所以表达式要写在select 与from之间
<4>.ifnull
ifnull(expr1,expr2):如果expr1 为空 返回 expr2 否则返回expr1
set @a:=null;
select ifnull(@a,2);
set @a:=10;
select ifnull(@a,19);
5
5
1
ifnull(expr1,expr2):如果expr1 为空 返回 expr2 否则返回expr1
2
set @a:=null;
3
select ifnull(@a,2);
4
set @a:=10;
5
select ifnull(@a,19);
<5>.NULLIF(expr1,expr2):
如果expr1 = expr2 成立,那么返回值为NULL,否则返回值为expr1这和Case when expr1 = expr2 then NULL ELSE expr1 END相同
eg:
select NULLIF(1,1)
3
3
1
如果expr1 = expr2 成立,那么返回值为NULL,否则返回值为expr1这和Case when expr1 = expr2 then NULL ELSE expr1 END相同
2
eg:
3
select NULLIF(1,1)
<6>.存储过程中为什么要使用DELIMITER
DELIMITER 是分隔符的意思,因为MySQL默认是以“;”为分隔符的,如果我们没有声明分隔符的话,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程就会报错,所以要事先用DELIMITER关键字声明当前段分割符,这样MySQL才会将“;”当做存储过程中的代码,不会执行这些代码,用完之后就把分隔符还原
<7>.存储过程与函数区别
存储过程参数分为输入和输出两类
用out和in表示存储过程用call来调用
存储过程参数还有inout型的参数 既可以当输入也可以当输出
存储过程中的控制语句都要有结束标志end
<8>.分支语句if…then…else ……end if;
DELIMITER $
create procedure pro_1()
begin
declare var int ;
set var = parameter +1;
if var=0 then
select * from user where id = 1058;
end if;
if parameter = 0 then
select * from user where id = 1060;
else
select * from user where id = 1059;
end if;
end $
DELIMITER ;
15
15
1
DELIMITER $
2
create procedure pro_1()
3
begin
4
declare var int ;
5
set var = parameter +1;
6
if var=0 then
7
select * from user where id = 1058;
8
end if;
9
if parameter = 0 then
10
select * from user where id = 1060;
11
else
12
select * from user where id = 1059;
13
end if;
14
end $
15
DELIMITER ;
DELIMITER $
create procedure pro_2()
begin
declare var int;
set var = 0;
while var<6 do
select var;
set var = var +1;
end while;
end $
DELIMITER ;
11
11
11
1
DELIMITER $
2
create procedure pro_2()
3
begin
4
declare var int;
5
set var = 0;
6
while var<6 do
7
select var;
8
set var = var +1;
9
end while;
10
end $
11
DELIMITER ;
DELIMITER $
create procedure pro_3()
begin
declare v int;
set v:=0;
repeat
select v;
set v = v+1;
until v>-5
end repeat;
end $
DELIMITER ;
12
12
1
DELIMITER $
2
create procedure pro_3()
3
begin
4
declare v int;
5
set v:=0;
6
repeat
7
select v;
8
set v = v+1;
9
until v>-5
10
end repeat;
11
end $
12
DELIMITER ;
DELIMITER $
create procedure pro_4()
begin
declare v int;
set v:=0;
LOOP_Lable:loop
select v;
set v = v+1;
if v >= 5 then
leave LOOP_Lable;#离开循环
end if;
end loop;
end $
DELIMITER ;
14
14
1
DELIMITER $
2
create procedure pro_4()
3
begin
4
declare v int;
5
set v:=0;
6
LOOP_Lable:loop
7
select v;
8
set v = v+1;
9
if v >= 5 then
10
leave LOOP_Lable;#离开循环
11
end if;
12
end loop;
13
end $
14
DELIMITER ;
MySQL存储过程中,定义变量有两种方式:
(1).使用set或select直接赋值,变量名以 @ 开头.例如:set @var=1;可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。
(2).以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如:
DECLARE var1 INT DEFAULT 0; 主要用在存储过程中,或者是给存储传参数中。
两者的区别是:
在调用存储过程时,以DECLARE声明的变量都会被初始化为 NULL。而会话变量(即@开头的变量)则不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在是这个会话内的全局变量。在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。
例:
set @v_sql= sqltext;
PREPARE stmt FROM @v_sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
5
5
1
例:
2
set @v_sql= sqltext;
3
PREPARE stmt FROM @v_sql;
4
EXECUTE stmt;
5
DEALLOCATE PREPARE stmt;
drop function if exists fun_1;
delimiter $
create function fun_1()returns int
begin
代码块
return 1;
end $
delimiter ;
8
8
1
drop function if exists fun_1;
2
delimiter $
3
create function fun_1()returns int
4
begin
5
代码块
6
return 1;
7
end $
8
delimiter ;
<1>.显示创建的存储过程语句
show create procedure pro_1<2>.显示所有存储过程的状态详细信息 show procedure status;<3>.显示所有函数的详细信息 show function status;<4>.显示具体函数得创建语句 show createfunction fun_1
8.Mysql存储过程和函数区别介绍
存储过程是用户定义的一系列sql语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表。
存储过程和函数存在以下几个区别: (1)一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作。 (2)对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象。函数只能返回一个变量;而存储过程可以返回多个。存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。 (3)存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。(4)存储过程一般是作为一个独立的部分来执行( EXECUTE 语句执行),而函数可以作为查询语句的一个部分来调用(SELECT调用),由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。 SQL语句中不可用存储过程,而可以使用函数。
9.使用存储过程与函数的原则:
(1).如果需要返回多个值和不放回值,就是用存储过程;如果只需要返回一个值,就用函数。
(2).函数不需要使用IN模式和OUT模式,它认为所有的参数都是IN的
(3).过程一般用于执行一个指定的动作,函数一般用于就计算和反回一个值。(4).可以SQL语句内部(如表达式)调用函数来完成复杂的计算问题,但不能调用过程。所以这是函数的特色。
10.更新数据
update movies set views = views+1 where Vid = 5;
1
1
1
update movies set views = views+1 where Vid = 5;
11.concat()函数中间的参数可以链接无数个,用逗号隔开
12.存储过程中也可以向高级语言一样可以定义准备语句,用于执行SQL语句 select insert ...等等
13.在存储过程中要想得到select 的查询结果就一定要用准备语句,才可以把结果在存储过程外得到返回值
prepare var_name from sql_str;#sql_str是select的字符串
execute var_name;
2
2
1
prepare var_name from sql_str;#sql_str是select的字符串
2
execute var_name;
15.mysql 导出数据库
mysqldump -u username -p db_name > 导出的数据库文件
1
1
1
mysqldump -u username -p db_name > 导出的数据库文件
<2> 备份多个数据库
mysqldump -u username -p --database dbname1 dbname2 > backup.sql;
1
1
1
mysqldump -u username -p --database dbname1 dbname2 > backup.sql;
<3>.备份所有数据库
mysqldump -u username -p --all-database > backup.sql;
x
1
1
mysqldump -u username -p --all-database > backup.sql;
<4>.数据库的还原
mysql -u root -p [dbname] <backup.sql
eg:mysql -u root -p < backup.sql;
2
2
1
mysql -u root -p [dbname] <backup.sql
2
eg:mysql -u root -p < backup.sql;
<5>.只恢复其中的一个数据库
mysql -u root -p db_name --one-database < backup.sql;
1
1
1
mysql -u root -p db_name --one-database < backup.sql;
16.mysql把用户的信息都存到了名为mysql的数据的数据库里来管理用户
select user from user;//查看所有用户
1
1
1
select user from user;//查看所有用户
show grants for user_name;
1
1
1
1
show grants for user_name;
18.为用户分配所有权限
grant all on *.* to username;
1
1
1
grant all on *.* to username;
19.declare continue handler for sqlstate '02000' set done = 1;
20.查看表的属性结构
<1>.desc <table_name>;
<2>.show columns from <table_name>
2
2
1
<1>.desc <table_name>;
2
<2>.show columns from <table_name>
alter table <table_name> drop column <column_name>;
1
1
1
alter table <table_name> drop column <column_name>;
alter table user change `password varchar` password varchar(20) character set utf8 not null
1
1
1
alter table user change `password varchar` password varchar(20) character set utf8 not null
alter table table_name change column_name rename_column_name column_type;
1
1
1
alter table table_name change column_name rename_column_name column_type;
27.java编程时只有存储过程中有parementstatement 语句是才能用execute
28.重命名数据库
rename database music to audio;
1
1
1
rename database music to audio;
29.mysql引擎类型区别
(1).InnoDB:是一个可靠地事物处理引擎,但是它不支持全文检索
(2).MEMORY:在功能等同于MyISAM,但由于数据库在内存中,速度很快,适用于临时表
(3).MyISAM:性能极高的引擎,支持全文搜索,不支持事物处理。
30.Mysql在进行使用UNION时column的数量一定要相等
31.Mysql添加主键
alter table video_type_config ADD
CONSTRAINT pk_Video_no PRIMARY KEY (video_no);
2
2
1
alter table video_type_config ADD
2
CONSTRAINT pk_Video_no PRIMARY KEY (video_no);
32.Mysql添加注释
表注释
ALTER TABLE table_name COMMENT='这是表的注释';
字段注释
ALTER table table_name
MODIFY `column_name` datetime DEFAULT NULL COMMENT '这是字段的注释'
6
6
1
表注释
2
ALTER TABLE table_name COMMENT='这是表的注释';
3
4
字段注释
5
ALTER table table_name
6
MODIFY `column_name` datetime DEFAULT NULL COMMENT '这是字段的注释'
33.查看字段的注释
33.查看字段的注释
SHOW FULL COLUMNS FROM video_type_config;
1
1
1
SHOW FULL COLUMNS FROM video_type_config;
34.MySQL查看具体字段使用情况所占空间
34.MySQL查看具体字段使用情况所占空间
#schema表示的是数据库(模式下有多个数据库schema:db=1:n)
-- use information_schema;
#table_schema表示的是数据库
SELECT TABLE_NAME, DATA_LENGTH + INDEX_LENGTH, TABLE_ROWS
FROM TABLES
WHERE TABLE_SCHEMA = 'video'
AND TABLE_NAME = 'video_type_config';
8
8
1
#schema表示的是数据库(模式下有多个数据库schema:db=1:n)
2
-- use information_schema;
3
4
#table_schema表示的是数据库
5
SELECT TABLE_NAME, DATA_LENGTH + INDEX_LENGTH, TABLE_ROWS
6
FROM TABLES
7
WHERE TABLE_SCHEMA = 'video'
8
AND TABLE_NAME = 'video_type_config';
35.MySQL查看变量的值
35.MySQL查看变量的值
select @@global.sql_mode
1
1
1
select @@global.sql_mode
36.MySQL为变量赋值
36.MySQL为变量赋值
set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
1
1
1
set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
37.MySQL查看表的状态(引擎、使用情况)
37.MySQL查看表的状态(引擎、使用情况)
show table status like 'video_type_config';
1
1
1
show table status like 'video_type_config';
38.mysql中查看表的状态采用G结尾的方式只能在命令行中进行,在navicat中不好使
38.mysql中查看表的状态采用G结尾的方式只能在命令行中进行,在navicat中不好使
show table status like 'video_type_config' G;
mysql> show table status like 'video_type_config' G;
*************************** 1. row ***************************
Name: video_type_config
Engine: InnoDB
Version: 10
Row_format: Dynamic
Rows: 156
Avg_row_length: 105
Data_length: 16384
Max_data_length: 0
Index_length: 0
Data_free: 0
Auto_increment: NULL
Create_time: 2017-04-28 09:29:48
Update_time: NULL
Check_time: NULL
Collation: latin1_swedish_ci
Checksum: NULL
Create_options:
Comment: 地址和类型配置表
1 row in set (0.01 sec)
x
23
1
show table status like 'video_type_config' G;
2
3
mysql> show table status like 'video_type_config' G;
4
*************************** 1. row ***************************
5
Name: video_type_config
6
Engine: InnoDB
7
Version: 10
8
Row_format: Dynamic
9
Rows: 156
10
Avg_row_length: 105
11
Data_length: 16384
12
Max_data_length: 0
13
Index_length: 0
14
Data_free: 0
15
Auto_increment: NULL
16
Create_time: 2017-04-28 09:29:48
17
Update_time: NULL
18
Check_time: NULL
19
Collation: latin1_swedish_ci
20
Checksum: NULL
21
Create_options:
22
Comment: 地址和类型配置表
23
1 row in set (0.01 sec)
39.MySQL计算字段的存储情况(按字节)
39.MySQL计算字段的存储情况(按字节)
SELECT
CONCAT(
SUM(CHAR_LENGTH(video_no)) / 1024,
'Kb'
) video_no,
CONCAT(
SUM(CHAR_LENGTH(video_type)) / 1024,
'Kb'
) video_type
FROM
video_type_config
ORDER BY
video_no,
video_type;
14
14
1
SELECT
2
CONCAT(
3
SUM(CHAR_LENGTH(video_no)) / 1024,
4
'Kb'
5
) video_no,
6
CONCAT(
7
SUM(CHAR_LENGTH(video_type)) / 1024,
8
'Kb'
9
) video_type
10
FROM
11
video_type_config
12
ORDER BY
13
video_no,
14
video_type;
40.MySQL表的最大允许多少字段
40.MySQL表的最大允许多少字段
在mysql中,每个数据库最多可创建20亿个表,一个表允许定义1024列,
1
1
1
在mysql中,每个数据库最多可创建20亿个表,一个表允许定义1024列,
41.MySql进行 group by 时,select后面的列一定要在分组内(group by),要不列的行数不对应会报错
42.MySQL查看索引使用状态
show status like ‘Handler_read%';
大家可以注意:
handler_read_key:这个值越高越好,越高表示使用索引查询到的次数
handler_read_rnd_next:这个值越高,说明查询低效
4
1
show status like ‘Handler_read%';
2
大家可以注意:
3
handler_read_key:这个值越高越好,越高表示使用索引查询到的次数
4
handler_read_rnd_next:这个值越高,说明查询低效
43.Mysql从win的mysql导出数据库一定要用cmd导出,不能使用power shell,否则会出现:如下代码
ERROR: ASCII ' ' appeared in the statement, but this is not allowed unless
1
1
1
ERROR ASCII ' ' appeared in the statement, but this is not allowed unless