Loading

表记录操作

表记录七十二变

基本操作

insert into 表 (列名,列名...) values (值,值,值...)
insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...)
insert into 表 (列名,列名...) select (列名,列名...) from 表

delete from 表 # 清空表,所以一定要加where
delete from 表 where id=1 and name='alex'

update 表 set name = 'alex' where id>1 # 不加where那么name一列都改为alex了

select * from 表
select * from 表 where id > 1
select nid,name,gender as gg from 表 where id > 1;

查用的最多,这只是最基本的,还有部分查,分组查,分页查,顺序倒序查,连表查,集合等等。

select 1,name,age from user  where id =3;
常量字段会作为额外列加入到查询结果里。

 其他查

a、条件
    select * from 表 where id > 1 and name != 'alex' and num = 12;
 
    select * from 表 where id between 5 and 16;
 
    select * from 表 where id in (11,22,33)
    select * from 表 where id not in (11,22,33)
    select * from 表 where id in (select nid from 表)
 
b、通配符
    select * from 表 where name like 'ale%'  - ale开头的所有(多个字符串)
    select * from 表 where name like 'ale_'  - ale开头的所有(一个字符)
 
c、分页  limit m  指的是1,5  从第一个开始取5行  分页主要用于数据的分批显示,不至于数据太多全部到内存中撑爆内存。
    select * from 表 limit 5;            - 前5行
    select * from 表 limit 4,5;          - 从第4行开始的5行
    select * from 表 limit 5 offset 4    - 从第4行开始偏移5行
 
d、排序 对筛选完的数据进行排序
    select * from 表 order by 列 asc              - 根据 “列” 从小到大排列
    select * from 表 order by 列 desc             - 根据 “列” 从大到小排列
    select * from 表 order by 列1 desc,列2 asc    - 根据 “列1” 从大到小排列,如果相同则按列2从小到大排序
 
e、分组,分组的目的是将多行记录进行合并,分组字段是合并的依据,而其他字段数据不一致,因此无法合并,所以其他字段只能用于分组函数中,不能作为select后面的查询字段
筛选数据先用where 这是第一次筛选
然后对筛选后的数据进行分组合并,
合并之后的数据再次筛选用having,后面只能是分组字段和分组函数
select后也只能是分组字段和分组函数 select num from 表 group by num select num,nid from 表 group by num,nid select num,nid from 表 where nid > 10 group by num,nid order nid desc select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid select num from 表 group by num having max(id) > 10 特别的:group by 必须在where之后,order by之前 f、连表 无对应关系则不显示 select A.num, A.name, B.name from A,B Where A.nid = B.nid 无对应关系则不显示 select A.num, A.name, B.name from A inner join B on A.nid = B.nid A表所有显示,如果B中无对应关系,则值为null select A.num, A.name, B.name from A left join B on A.nid = B.nid B表所有显示,如果B中无对应关系,则值为null select A.num, A.name, B.name from A right join B on A.nid = B.nid g、组合 组合,自动处理重合 select nickname from A union select name from B 组合,不处理重合 select nickname from A union all select name from B

 

posted @ 2020-11-08 14:51  浅忆尘  阅读(57)  评论(0编辑  收藏  举报