文章目录
  1. 1. 数据库操作
  2. 2. 表操作
  3. 3. 基本sql语句
  4. 4. 几个高级查询运算词
  5. 5. 外连接
  6. 6. 流程控制语句

之前介绍了一些Mysql比较底层的东西,但是一直没有涉及到具体的使用,本文就特定整理一下Mysql的基本语法。

数据库操作

  1. 创建数据库

    Create DATABASE database-name 
    
  2. 删除数据库

    drop database dbname 
    
  3. 备份sql server

    — 创建 备份数据的 device

    USE master 
    EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' 
    

    — 开始 备份

    BACKUP DATABASE pubs TO testBack 
    

表操作

  1. 创建新表

    create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) 
    

    根据已有的表创建新表:

    create table tab_new like tab_old (使用旧表创建新表) 
    create table tab_new as select col1,col2… from tab_old definition only 
    
  2. 删除新表

    drop table tabname 
    
  3. 增加一个列

    Alter table tabname add column col type 
    

    列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。

  4. 添加主键

    Alter table tabname add primary key(col) 
    
  5. 删除主键

    Alter table tabname drop primary key(col) 
    
  6. 创建索引

    create [unique] index idxname on tabname(col….) 
    
  7. 删除索引

    drop index idxname 
    

    索引是不可更改的,想更改必须删除重新建。

  8. 创建视图

    create view viewname as select statement 
    
  9. 删除视图

    drop view viewname 
    

基本sql语句

  1. 选择

    select * from table1 where 范围 
    
  2. 插入

    insert into table1(field1,field2) values(value1,value2) 
    
  3. 删除

    delete from table1 where 范围 
    
  4. 更新

    update table1 set field1=value1 where 范围 
    
  5. 查找

    select * from table1 where field1 like '%value1%' 
    
  6. 排序

    select * from table1 order by field1,field2 [desc]
    
  7. 总数

    select count as totalcount from table1 
    
  8. 求和

    select sum(field1) as sumvalue from table1 
    
  9. 平均

    select avg(field1) as avgvalue from table1
    
  10. 最大

    select max(field1) as maxvalue from table1
    
  11. 最小

    select min(field1) as minvalue from table1 
    
  12. between限制查询数据范围时包括了边界值,not between不包括

    select * from table1 where time between time1 and time2 
    select a,b,c, from table1 where a not between 数值1 and 数值2 
    
  13. in 的使用方法

    select * from table1 where a [not] in (‘值1','2','4','6') 
    

几个高级查询运算词

  1. UNION 运算符

    UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。

  2. EXCEPT 运算符

    EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。

  3. INTERSECT 运算符

    INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。

外连接

  1. left outer join

    左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。

    select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 
    
  2. right outer join

    右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行

  3. full outer join

    全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录

流程控制语句

  1. if

    IF(expr1,expr2,expr3)
    

    如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF()的返回值为数字值或字符串值,具体情况视其所在语境而定。例如

    mysql> SELECT IF(1>2,2,3)   ->3
    
  2. case

    CASE (value)
        WHEN expr THEN value1 
        ........
        ELSE value2 END
    
  3. ifnull

    SELECT IFNULL(expr1, expr2); 
    

    如果 expr1不为null,则返回expr1,如果expr1为null,则返回expr2

  4. nullif

    SELECT NULLIF(expr1,expr2); 
    

    如果expr1=expr2,则返回null,否则返回expr1

  5. loop 与 leave,iterate 实现循环

    [begin_lable :]loop
                        statement_list
                       end loop [end _lable]
    

    loop 标志位无条件循环,leave 类似于break 语句,跳出循环,跳出 begin end,iterate 类似于continue ,结束本次循环

  6. repeat

    [begin_lable:] repeat
                     statement_list;
                    until search_condition ;
                   end repeat ;
    

    有条件的循环语句 当满足条件时循环退出 类似与 do while循环 循环体至少被执行一次

  7. while

    [begin_lable:] while search_condition do
                       statement_list;
                   end while [end_label] ;
    

    满足条件执行,循环体可以 被执行 0 次

文章目录
  1. 1. 数据库操作
  2. 2. 表操作
  3. 3. 基本sql语句
  4. 4. 几个高级查询运算词
  5. 5. 外连接
  6. 6. 流程控制语句