zoukankan      html  css  js  c++  java
  • MySQL

    1.描述表得结构

         desc table_name;

    2.删除表中得数据

        delete from table_name where [约束条件]

    3.可变浮点数定义用decimal(n,m)

        n :是浮点数的(二进制)位数
        m:是小数分的位数
        eg:decimal(10,2) 

    4.标准的存储过程模板如下:

    drop procedure if exists pro_1;
    delimiter $
    create procedure pro_1(
    
    
    )
    begin
    end $
    delimiter ;
    5.存储过程的基本语法

     <1>.设置变量                 

    set @var_name = 0,@var_id = 12;
    select @var_name , @var_id;
     <2>.流程控制

    select username,
    case username
    when 'belong' then 'handsome'
    when 'tom' then 'sou'
    else 'ban'
    end
    from user;
    结果如下: 

      红色部分就是查询的第二个字段

    <3>.if

    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>.NULLIF(expr1,expr2):

         

     如果expr1 = expr2 成立,那么返回值为NULL,否则返回值为expr1这和Case when expr1  = expr2 then NULL ELSE expr1 END相同
            eg:
           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 ;
    <9>.While循环:

    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 ;
    <10>.Repeat循环:

    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 ;
    <11>.LOOP循环:

    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 ;
    6.MySQL中declare 与 set 的区别

    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;
    6.5函数模板

    drop function if exists fun_1;
    delimiter $
    create function fun_1()returns int 
    begin
    	    代码块
        return 1;
    end $
    delimiter ;
    7.sql语句

    <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

    11.concat()函数中间的参数可以链接无数个,用逗号隔开

    12.存储过程中也可以向高级语言一样可以定义准备语句,用于执行SQL语句 select insert ...等等

    13.在存储过程中要想得到select 的查询结果就一定要用准备语句,才可以把结果在存储过程外得到返回值

    prepare var_name from sql_str;#sql_str是select的字符串
    execute var_name;
    14.join on 就是按on的条件将所加入的表与原表组合在一起

    15.mysql 导出数据库 

     mysqldump -u username -p db_name > 导出的数据库文件

    <2> 备份多个数据库

    mysqldump -u username -p  --database dbname1 dbname2 > backup.sql;
    <3>.备份所有数据库

    mysqldump -u username -p --all-database > backup.sql;
    <4>.数据库的还原

     mysql -u root -p [dbname] <backup.sql 
    eg:mysql -u root -p < backup.sql;
    <5>.只恢复其中的一个数据库

        mysql -u root -p db_name --one-database < backup.sql;

    16.mysql把用户的信息都存到了名为mysql的数据的数据库里来管理用户

     select user from user;//查看所有用户
    17.显示用户的权限

        show grants for user_name;

    18.为用户分配所有权限 

        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>
    24.删除表的某个字段

    alter table <table_name> drop column <column_name>;
    25.当表中的字段名和MySQL的关键字重名时要使用 数字键旁边的点作为转义才可以改变

    <span data-wiz-span="data-wiz-span" style="font-size: 1.067rem;">Untitled</span>

    alter table user change `password varchar` password varchar(20) character set utf8 not null
    26.表重命名

    <span data-wiz-span="data-wiz-span" style="font-size: 1.067rem;">Untitled</span>

    alter table table_name change column_name rename_column_name column_type;
    27.java编程时只有存储过程中有parementstatement 语句是才能用execute 
    28.重命名数据库
    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);
    32.Mysql添加注释
    表注释
    ALTER TABLE table_name COMMENT='这是表的注释';  
    
    字段注释
    ALTER table table_name 
    MODIFY `column_name` datetime DEFAULT NULL COMMENT '这是字段的注释'  
    33.查看字段的注释
    SHOW FULL COLUMNS  FROM video_type_config;
    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';
    35.MySQL查看变量的值
    select @@global.sql_mode
    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';
    37.MySQL查看表的状态(引擎、使用情况)
    show table status like 'video_type_config';
    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)
    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;
    40.MySQL表的最大允许多少字段
    在mysql中,每个数据库最多可创建20亿个表,一个表允许定义1024列,

    41.MySql进行 group by 时,select后面的列一定要在分组内(group by),要不列的行数不对应会报错
    42.MySQL查看索引使用状态
    show status like ‘Handler_read%';
    大家可以注意:
    handler_read_key:这个值越高越好,越高表示使用索引查询到的次数
    handler_read_rnd_next:这个值越高,说明查询低效
    43.Mysql从win的mysql导出数据库一定要用cmd导出,不能使用power shell,否则会出现:如下代码
    ERROR: ASCII '' appeared in the statement, but this is not allowed unless









  • 相关阅读:
    centos 7 端口
    linux yum
    linux RPM包管理
    linux 进程
    linux 显示系统执行的进程
    linux 任务调度
    linux 组管理
    linux 压缩和解压缩
    linux 文件目录类的指令 包含查找
    PHP指定字段的多维数组排序方法
  • 原文地址:https://www.cnblogs.com/Mrbelong/p/7634675.html
Copyright © 2011-2022 走看看