*特别说明:FILED代表数据表字段,CONDITIONS代表where之后的条件,TABLENAME代表数据表名   []中括号内的内容代表 可有可无。

  创建数据库

    create  database  DATABASE;

  删除数据库

    drop database  DATABASE

  创建数据表

    create   table TABLENAME(

      `id`   int   unsigned  auto_increment  primary key,     //把id设置为主键,数据类型是无符号int型,自动递增

            //注:unsigned 只能紧跟在数据类型 后,顺序不能乱  unsigned相当于去掉数字负数部分   例:tinyint  默认取值范围 -128到127  unsigned 后  取值范围变 0到 255

      `userid`   int   unsigned references  FOREIGNTABLE(FOREIGNFILED),  //把userid设置为无符号整型,并设置成外键。关联主键表(FOREIGNTABLE)中的主键(FOREIGNFILED)

      `imgid`   int  unsigned  not null default 1  comment '图片ID',   //把imgid  设置成无符号整数  且不为空  默认值为1  注释说明为  “图片ID”

      foreign key(imgid)  references  FOREIGNTABLE(FOREIGNFILED)    //设置  imgid 为外键。 关联主键表(FOREIGN_TABLE)中的主键(FOREIGN_FILED)   (下同)

    )engine=MYISAM  default charset=utf8  collate=utf8_general_ci    //设置数据表引擎为MYISAM  ,默认字符集为utf8  且字符集排序规则为   utf8_general_ci

  删除数据表

    drop table if  exists TABLENAME;

  添加字段

    alter table TABLENAME   add  colum  FIELD   DATATYPE   ATTRIBUTES    //DATATYPE   :字段数据类型     ATTRIBUTES字段属性

    eg:  alter table test  ADD COLUMN  ceshi varchar(50)  not null default ''  comment  '测试字段'

  删除字段

    alter table TABLENAME   drop colum  FIELD ;

    eg:alter table test  DROP COLUMN  ceshi;

  修改字段属性

    alter table  TABENAME modify FIELD char(10) default 0 COMMENT "这是整数";

  修改字段名称

    alter table TABENAME  change FIELD mytest int unsigned not null default 1;

  添加默认值

    eg:   alter table test alter column user_id set default 1;

  删除默认值

    alter table TABENAME alter column FIELD drop default;

  设置主键

    alter table TABENAME add primary key(FIELD1  [ ,FIELD2,.. ] );

  删除主键

    alter table TABLENAME drop primary key;   //注意:如果表里的主键是具有自增长属性的;那么直接删除是会报错的

  添加唯一索引

    alter table TABLENAME    add  constraint   KEY_NAME  unique(FIELD);   //KEY_NAME  :索引名称  (下同)

  添加外键索引

    alter table TABLENAME    add  constraint   KEY_NAME  foreign key(FIELD)  references  FOREIGN_TABLE(FOREIGN_FIELD) ;

  删除索引(外键、唯一)

    alter  table  TABLENAME    drop  index KEY_NAME

    或

    alter  table  TABLENAME    drop  key  KEY_NAME

  检查约束 :注意,MYSQL 目前并不支持check检查约束。可以用以下方法,设置字段为枚举值

    eg:   alter table TABENAME modify sex ENUM("男","女");

  修改表的存储引擎

    alter table TABENAME engine=INNODB

  修改数据表的自增长值

    alter table TABENAME AUTO_INCREMENT=100;

  添加数据

    insert  [ into ]  TABLENAME (FIELD1,FELD2,...)  values(值1,值2,值3,...) ,(值1,值2,值3,...),...

  修改数据

    update  TABLENAME   set FILED1=值1,FEILD2=值2,....  where   CONDITISONS

  删除数据

    delete  from  TABLENAME    [  where  CONDITIONS ];

  清空数据

    truncate   table   TABLENAME;   自增ID会重置。

  查询数据表所有

    select  from   TABLENAME

  统计查询(查询结果集中的数据条数)

    select count(FIELD)  from  TABLENAME  [ where  CONDITIONS]

  查询某个字段的最大、最小、平均、求和的值

  select max(FIELD)  from TABLENAME  [where  CONDITIONS];

  select min(FIELD)  from  TABLENAME  [where  CONDITIONS];

  select  avg(FIELD)  from  TABLENAME  [where  CONDITIONS];

  select  sum(FIELD)  from  TABLENAME  [where  CONDITIONS];

  排序查询

  select  *  from   TABLENAME  [ where CONDITIONS]   order by FIELD ;  从小到大排

  select  *  from   TABLENAME  [ where CONDITIONS]   order by FIELD  desc;  从大到小排

  限制查询

  select * from TABLENAME   [ where CONDITIONS]   [ order by FIELD ]  limit START,NUM      //START代表数据集的开始位置,0为第一条数据的位置,依次往后为数据的位置。NUM代表限制数据集的数据条数。至少1条。

  去重查询

  select distinct  FILED1,FIELD2,...  from  TABLENAME    [ where CONDITIONS]   [ order by FIELD ]  [ limit START,NUM ]   //代表FIELD1,FIELD2,....所有字段都重复时,才去除重复的数据条。

  分组查询  (  group  by  FIELD)

   示例::select name, first_letter,sum(parent_id) as cid  from mm_city where `parent_id` = 18 group by   first_letter  having cid>50   limit 0,1   //顺序不能乱。当有统计字段别名做条件时,不能用where,只能用 having。

  模糊查询

    select *  from  TABLENAME  where FIELD like  '%值%';      //  %  代表任意多个任意字符

  内连接查询

    select  TABLENAME1.FIELD1,TABLENAME2.FIELD2,TABLENAME3.FIELD3,...  from  TABLENAME1

    join  TBALENAME2  on TABLENAME1.FIELD  = TABLENAME2.FIELD

    ( join  TBALENAME3  on TABLENAME1.FIELD  = TABLENAME3.FIELD )  

    或

    ( join  TBALENAME3 on TABLENAME2.FIELD  = TABLENAME3.FIELD  )

    [  where   TABLENAME1.FIELD = 值 ...  ]        //查询或作为条件的字段中,若所有表中任意两张表都有该字段,则必须要指明数据表。即在字段前用 表名连上点(.)

  外连接

    左联接:left join   ;查询出来的数据,若有空值,则以在left join前面的表中的数据条数为准

    select  TABLENAME1.FIELD1,TABLENAME2.FIELD2,TABLENAME3.FIELD3,...  from  TABLENAME1

    left join  TBALENAME2  on TABLENAME1.FIELD  = TABLENAME2.FIELD

    (left  join  TBALENAME3  on TABLENAME1.FIELD  = TABLENAME3.FIELD )  

    或

    (left join  TBALENAME3 on TABLENAME2.FIELD  = TABLENAME3.FIELD  )

    [  where   TABLENAME1.FIELD = 值 ...  ]        //查询或作为条件的字段中,若所有表中任意两张表都有该字段,则必须要指明数据表。即在字段前用 表名连上点(.)

    

    右联接:rightjoin   ;查询出来的数据,若有空值,则以在left join后面的表中的数据条数为准

    select  TABLENAME1.FIELD1,TABLENAME2.FIELD2,TABLENAME3.FIELD3,...  from  TABLENAME1

    right join  TBALENAME2  on TABLENAME1.FIELD  = TABLENAME2.FIELD

    (right join  TBALENAME3  on TABLENAME1.FIELD  = TABLENAME3.FIELD )  

    或

    (right join  TBALENAME3 on TABLENAME2.FIELD  = TABLENAME3.FIELD  )

    [  where   TABLENAME1.FIELD = 值 ...  ]        //查询或作为条件的字段中,若所有表中任意两张表都有该字段,则必须要指明数据表。即在字段前用 表名连上点(.)

  常用数据库函数

    LENGTH  :返回字符串或列的数据的长度

      eg: select length(city)  as citylen  from  Demo

    lower/upper:返回字符串的小写/大写

      eg: select UPPER(account)  from admininfo;

    REPLACE :替换字符串
      eg: select REPLACE('SQL SERVER','SQL','sql') 结果是'sql SERVER'   

    POWER() 取数值的幂值

      eg:select POWER(5,3) 结果是125

    ABS 返回绝对值

      eg:select ABS(-99) 结果是99

    ROUND 根据指定精度返回数值的四舍五入

      eg: select ROUND(3.1415926,3) 结果是3.142

  

  数据库对象

    存储过程

      drop procedure if exists pr_multi;   //如果存在名为pr_multi的存储过程,则删掉
      create procedure pr_multi( out c int, a int, b int )      //创建名为pr_multi的存储过程(函数),第一个为数据类型int的输出参数,第二、三个分别为数据类型int的输入参数
      begin              //过程体开始标记
        if a is null THEN         //判断  a 参数是否为空,若果为空,
          set a=10;      //给  a赋值10
        end if;
        if b is null THEN     //判断  b 参数是否为空,若果为空,
          set b=20;     //给  b 赋值20
        end if;     
        set c=a*b;      //将参数c设置为  a  和  b  的乘积
      end               //过程体结束标记

      call pr_multi(@name,5,3);    //调用存储过程pr_multi     用变量  name  接收输出参数  c  ,给参数  a  传值  5,b传值  3

      select @name     //查询变量name的值。。  上述结果为  15

      详情请看  https://www.cnblogs.com/bobi-PHP-blog/p/7501392.html

    视图

      create view  VIEWNAME    //VIEWNAME    视图名称 (下同)

      as

      SELECTBLOCK   //查询语句

      eg:

        create  view  myview  as  select   name,age,sex from users  where  id   > 10;

      查询视图:  select   FIELDS  from VIEWNAME  

    触发器:

      create trigger  自定义名称

      after | before       insert | update | delete     on  表名  for each row

      begin

        SQL语句集

      end

        eg: 

          create trigger mytrigger AFTER  insert on users for each row

          BEGIN 

            insert into depts(`deptname`,`create_at`) VALUES('测试','2018-06-19 20:20:20');

            update depts set create_at = CURRENT_TIMESTAMP where id=1827;

          END

    事件: 

      请参考:https://www.cnblogs.com/bobi-PHP-blog/p/7506306.html

      

      

    

  

    

  

MYSQL数据库SQL语句集锦的更多相关文章

  1. Mysql 常用 SQL 语句集锦

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  2. Mysql 常用 SQL 语句集锦 转载(https://gold.xitu.io/post/584e7b298d6d81005456eb53)

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  3. MySQL 数据库SQL语句——高阶版本2

    MySQL 数据库SQL语句--高阶版本2 实验准备 数据库表配置: mysql -uroot -p show databases; create database train_ticket; use ...

  4. MySQL 数据库SQL语句——高阶版本1

    MySQL 数据库SQL语句--高阶版本 实验准备,数据表配置 mysql -uroot -p show databases; create database train_ticket; use tr ...

  5. MySQL数据库SQL语句基本操作

    一.用户管理: 创建用户: create user '用户名'@'IP地址' identified by '密码'; 删除用户: drop user '用户名'@'IP地址'; 修改用户: renam ...

  6. MySQL数据库sql语句的一些简单优化

    1.查询条件的先后顺序 有多个查询条件时,要把效率高能更精确筛选记录的条件放在后边.因为MySQL解析sql语句是从后往前的(不知是否准确). 例: select a.*,b.* from UsrIn ...

  7. mySQL数据库Sql语句执行效率检查--Explain命令

    mysql性能的检查和调优方法 Explain命令在解决数据库性能上是第一推荐使用命令,大部分的性能问题可以通过此命令来简单的解决,Explain可以用来查看SQL语句的执行效 果,可以帮助选择更好的 ...

  8. MySQL 数据库--SQL语句优化

    explain查询和分析sql 开发中,为满足一业务功能,使用mysql书写sql时,一条sql往往有多种写法,那么我们就需要选择执行效率比较高的sql. 因此要比较分析sql的执行过程,且同一条sq ...

  9. MySql数据库SQL语句将编码

    -- 查看所有字符编码 SHOW CHARACTER SET; -- 查看创建数据库的指令并查看数据库使用的编码 show create database dbtest; -- 查看数据库编码: sh ...

随机推荐

  1. PAT甲级——1135 Is It A Red-Black Tree (30 分)

    我先在CSDN上面发表了同样的文章,见https://blog.csdn.net/weixin_44385565/article/details/88863693 排版比博客园要好一些.. 1135 ...

  2. 17.TLB

    我们只想读4个字节,但我们要经过如下的步骤 读取 字节的PDE 读取 字节的 PTE 读取 字节(int 占用4字节)的物理内存 在 10-10-12 分页模式下,CPU 每次要访问额外的访问 8 字 ...

  3. [題解]luogu_P1120小木棍(搜索)

    好久以前抄的題解,現在重新抄題解做一下 1.對所有木棍從大到小排序,後用小的比較靈活 2.限制加入的木棍單調遞減,因為先/后用長/短木棍等價,反正就是那兩根 3.預處理出重複木棍的位置,防止重複搜索相 ...

  4. 捕获异常try-catch-finally

    异常分类 try-carch-finally出现规则 return关键字的使用 finally中慎用return,虽然语法上没错,但是由于finally的强制执行,影响逻辑上需要return的值 pa ...

  5. JAVA常用知识总结(十三)——数据库(三)

    Mysql的主键选择(主键自增,UUID,snowflake)? 使用自增长做主键的优点:1.很小的数据存储空间2.性能最好3.容易记忆使用自增长做主键的缺点:1.如果存在大量的数据,可能会超出自增长 ...

  6. 06.Javascript——入门this的用法(难点)

    this 的指向 this 是 js 中定义的关键字,它自动定义于每一个函数域内,但是它的指向却让人很迷惑.在实际应用中,this 的指向大致可以分为以下四种情况. 1.作为普通函数调用 当函数作为一 ...

  7. JVM垃圾回收机制三

    垃圾回收器 分代垃圾回收常见的垃圾回收器 判断一个垃圾回收器好坏的标准 1.吞吐量越高越好 2.工作线程暂停时间越短越好. Serial垃圾回收器 串行回收器时最古老的最基本的垃圾回收器,工作线程会产 ...

  8. CSS选择器手册

    CSS选择器手册 选择器       选择器名称         例子 例子描述 CSS E.class 类选择器 E.intro 选择 class="intro" 的所有E元素. ...

  9. [windows]桌面中添加我的电脑,我的文档和网上邻居图标

    xp系统: 操作步骤:桌面任意位置--〉右键--〉属性--〉桌面选项卡--〉自定义桌面--〉常规:勾选相关图标确定即可. win7系统: 操作步骤:桌面任意位置--〉右键--〉个性化--〉(右侧)更改 ...

  10. Nengo 神经网络

    Nengo被加拿大滑铁卢大学的神经学家和软件工程师表示,这是迄今为止产生的世界上最复杂.最大规模的人类大脑模型模拟.这个名叫Spaun的大脑由250万 个模拟神经元组成,它能执行8种不同类型的任务.这 ...