一、表单操作
1-1.创建表
  create table tb_name( id in primary key auto_increment); 
 
1-2.查看表
  desc table_name;
  show create table tb_name \G
 
1-3.修改表名
  alter table old_name rename new_name;
 
1-4.增加字段
  4-1.在表的最后一个位置增加字段
  alter table tb_name add 字段名 数据类型等;
  4-2.在表的第一个位置增加字段
  alter table tb_name add 字段名 数据类型等 first;
  4-3.在表的指定位置增加字段
  alter table tb_name add 字段名 数据类型等 after 指定字段;
 
1-5.删除字段
  alter table tb_name drop 字段名;
 
1-6.修改字段
  a.修改字段的数据类型
  alter table tb_name modify 字段名 数据类型;
  b.修改字段的名字
  alter table tb_name change 旧字段名 新字段名 新数据类型;
 
二、Mysql-子查询

a、带in的子查询
  当主查询的条件在子查询的结果中时

b、带any的子查询
  1、=any:功能与in效果一样
  2、>any:比子查询返货的数据记录最小值,还要大
  3、<any:比子查询返回的数据记录最大值,还要小

c、带all的子查询
  >all:比子查询返回记录中最大的还要大
  <all:比子查询返回记录中最小的还要小
例子:查询年薪比“卡特”高的球员

mysql> select name,year_wage from tb_player where year_wage > all(selec t name,year_wage from tb_player where name="卡特");
 
查询,位置和月奖金,与“卡特”一样的球员
mysql> select name,position,month_bonus from tb_player where (position,month_bon
us)=(select position,month_bonus from tb_player where name="卡特");
 
d、exist查询,tb_player中 tb_team 没有的球队
 select name from tb_team as t
 where not exists(select team from tb_player where team=t.name);
 
e、from查询
    select tmp.team,max(tmp.year_wage) from (select team,year_wage from tb_player group by team,name) as tmp group by tmp.team;
 
三、Mysql-左连接和右连接(left join和right join)

表A记录如下: 
aID        aNum 
1           a20050111 
2           a20050112 
3           a20050113 
4           a20050114 
5           a20050115 
表B记录如下: 
bID        bName 
1           2006032401 
2           2006032402 
3           2006032403 
4           2006032404 
8           2006032408

实验如下: 
1.left join 
sql语句如下:

SELECT * 
   FROM A 
     LEFT JOIN B 
      ON A.aID = B.bID

结果如下: 
aID        aNum                   bID           bName 
1            a20050111         1               2006032401 
2            a20050112         2              2006032402 
3            a20050113         3              2006032403 
4            a20050114         4              2006032404 
5            a20050115         NULL       NULL 
(所影响的行数为 5 行)

结果说明: 
        left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的.换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID). 
B表记录不足的地方均为NULL.

2.right join 
sql语句如下:

SELECT * 
  FROM A 
    RIGHT JOIN B 
      ON A.aID = B.bID

结果如下: 
aID        aNum                   bID           bName 
1            a20050111         1               2006032401 
2            a20050112         2              2006032402 
3            a20050113         3              2006032403 
4            a20050114         4              2006032404 
NULL    NULL                8              2006032408 
(所影响的行数为 5 行)

结果说明: 
        仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充.

3.inner join 
sql语句如下:

SELECT * 
  FROM A 
    INNER JOIN B 
      ON A.aID = B.bID

结果如下: 
aID        aNum                   bID           bName 
1            a20050111         1              2006032401 
2            a20050112         2              2006032402 
3            a20050113         3              2006032403 
4            a20050114         4              2006032404

结果说明: 
        很明显,这里只显示出了 A.aID = B.bID的记录.这说明inner join并不以谁为基础,它只显示符合条件的记录.

-----------------[以下为网上的一点资料]------------------ 
LEFT JOIN操作用于在任何的 FROM 子句中,组合来源表的记录。使用 LEFT JOIN 运算来创建一个左边外部联接。左边外部联接将包含了从第一个(左边)开始的两个表中的全部记录,即使在第二个(右边)表中并没有相符值的记录。

语法: 
FROM table1 LEFT JOIN table2 ON table1.field1 compopr table2.field2

说明: 
① table1, table2参数用于指定要将记录组合的表的名称。 
② field1, field2参数指定被联接的字段的名称。且这些字段必须有相同的数据类型及包含相同类型的数据,但它们不需要有相同的名称。 
③ compopr参数指定关系比较运算符:"=", "<", ">", "<=", ">=" 或 "<>"。 
④ 如果在INNER JOIN操作中要联接包含Memo 数据类型或 OLE Object 数据类型数据的字段,将会发生错误。

Mysql数据库常规操作(建表、查询)的更多相关文章

  1. mysql数据库(一):建表与新增数据

    一. 学习目标 理解什么是数据库,什么是表 怎样创建数据库和表(create) 怎样往表里插入数据(insert) 怎样修改表里的数据(update) 怎样删除数据库,表以及数据(delete) 二. ...

  2. MySQL数据库篇之多表查询

    主要内容: 一.多表连接查询 二.复合条件连接查询 三.子查询 1️⃣  多表连接查询 一.准备表 #建表 create table department( id int, name varchar( ...

  3. MySQL数据库篇之单表查询

    主要内容: 一.单表查询的语法 二.关键字的执行优先级 三.简单查询 四.where约束 五.分组查询 group by 六.having过滤 七.查询排序 order by 八.限制查询的记录数 l ...

  4. java中用activiti插件连接mysql数据库,自动建表过程中,在配置mysql架包路径“org.activiti.engine.ActivitiException: couldn't check if tables “

    java中用activiti插件连接mysql数据库,出现错误: org.activiti.engine.ActivitiException: couldn't check if tables are ...

  5. MySQL数据库 字段操作 多表关系(更新中...)

    外键 (foreign key) ## 外键 ```mysql # 作者(author):id,name,sex,age,mobile, detail_id # 作者详情(author_detail) ...

  6. mysql数据库中的多表查询(内连接,外连接,子查询)

    用两个表(a_table.b_table),关联字段a_table.a_id和b_table.b_id来演示一下MySQL的内连接.外连接( 左(外)连接.右(外)连接.全(外)连接). MySQL版 ...

  7. 非关心数据库无法进行连表查询 所以我们需要在进行一对多查询时候 无法满足 因此需要在"1"的一方添加"多"的一方的的id 以便用于进行连表查询 ; 核心思想通过id进行维护与建文件

     非关心数据库无法进行连表查询 所以我们需要在进行一对多查询时候 无法满足 因此需要在"1"的一方添加"多"的一方的的id 以便用于进行连表查询 ; 核心思想通 ...

  8. mysql 数据操作 单表查询 目录

    mysql 数据操作 单表查询 mysql 数据操作 单表查询 简单查询 避免重复DISTINCT mysql 数据操作 单表查询 通过四则运算查询 mysql 数据操作 单表查询 concat()函 ...

  9. mysql 数据操作 多表查询 目录

    mysql 数据操作 多表查询 准备 多表连接查询介绍 mysql 数据操作 多表查询 多表连接查询 笛卡尔积 mysql 数据操作 多表查询 多表连接查询 内连接 mysql 数据操作 多表查询 多 ...

随机推荐

  1. 2015 Multi-University Training Contest 1 y sequence

    Y sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total ...

  2. LaTeX 设置字体颜色

    本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/50240179 需要包含宏包: \use ...

  3. light oj 1317

    Description You probably have played the game "Throwing Balls into the Basket". It is a si ...

  4. m_Orchestrate learning system---二十六、动态给封装好的控件添加属性

    m_Orchestrate learning system---二十六.动态给封装好的控件添加属性 一.总结 一句话总结:比如我现在封装好了ueditor控件,我外部调用这个控件,因为要写数据到数据库 ...

  5. mDNS原理的简单理解——每个进入局域网的主机,如果开启了mDNS服务的话,都会向局域网内的所有主机组播一个消息,我是谁,和我的IP地址是多少。然后其他也有该服务的主机就会响应,也会告诉你,它是谁,它的IP地址是多少

    MDNS协议介绍 mDNS multicast DNS , 使用5353端口,组播地址 224.0.0.251.在一个没有常规DNS服务器的小型网络内,可以使用mDNS来实现类似DNS的编程接口.包格 ...

  6. vue --- 路由传参的几种方式

    方案一: getDescribe(id) { // 直接调用$router.push 实现携带参数的跳转 this.$router.push({ path: `/describe/${id}`, }) ...

  7. 8.变量内存CPU原理

    编译器先明确是什么类型,然后明确变量名,变量表管理所有的变量,不在变量表内部的变量不能引用.每个变量对应一整块内存 a+1所计算出来的值在寄存器中,只有变量可以被赋值,变量必须在内存里面 c语言内嵌汇 ...

  8. 系统丢失的DLL文件问题根源解决(纯净官网下载放心)(图文详解)(博主推荐)

    导言 最近,身边的朋友们,问我,他电脑的win10系统里 mfc110.dll 丢失. 其他的系统文件丢失修复,是一样的步骤. 现象 大家也许,都会有这么一个习惯,动不动则就去百度上搜索. 其实啊,这 ...

  9. ES6中常用的简写方式

    1. var foo = 'bar'; var baz = {foo}; baz // {foo: "bar"} // 等同于 var baz = {foo: foo}; 2. f ...

  10. [笔记-统计学习方法]感知机模型(perceptron) 原理与实现

    前几天认把感知机这一章读完了,顺带做了点笔记 现在把笔记做第三次的整理 (不得不说博客园的LaTex公式和markdown排版真的不太舒服,该考虑在服务器上建一个博客了) 零.总结 适用于具有线性可分 ...