标签:
语法:
????create table 表B like 表A;
示例:
语法:
????create table 表B select *或字段列表 from 表A;
语法:
????insert into 表名【(字段列表)】 select *或字段列表 from 表名;
????限制修改指定的行数。
语法:
????update 表名 set 字段=值... 【where子句】 limit n;
说明:
????在执行update语句时,限制最多修改n行
示例:
????限制删除的行数
语法:
????delete from 表名 【where 子句】 limit n;
说明:
????用于限制最多只能删除n条记录
示例:
基本语法:
????insert into 表名【(字段列表)】 values(值列表);
主键冲突
????insert into 表名【(字段列表)】 values(值列表) on duplicate key update 字段=值,字段=值...;
示例:
说明:
????主键冲突的方式也可应用在唯一键冲突。
同理
replace into 表名【字段列表】 values(值列表);
说明:
????在主键冲突或唯一键冲突时,替换冲突的记录
示例:
标准语法:
????select 【all|distinct】 *|字段列表|字段名 【as】 别名 from 数据源 【where子句】【group by子句】【having子句】【order by 子句】【limit子句】
?
说明:
????all(缺省)????表示显示所有的记录(包含重复的记录)
????distinct????????表示不显示重复的记录(去掉重复记录)
示例:
语法:
????字段名 【as】 别名
示例:
说明:
????只是在显示的更改字段的名子,并没有更改表结构中的字段的名子。
????一般是用在多表查询时
语法:
????from 表名 【as】 表别名
示例:
?
数据的来源,数据的来源可以分3种:
1、单表数据源
????select * from 表名;
2、多表数据源
????select * from 表A,表B;
说明:
????将多个表的字段进行横向连接,
????记录数相乘
????术语:迪卡尔积
示例:
3、子查询数据源
select语句查询的结果是一个结果集,那再将此结果集作为from的一个数据源,此种数据源即为子查询数据源
示例:
说明:
????子查询数据源,必须将子查询使用括号括起来,并且设置一个别名
根据条件进行数据筛选,条件即为一个表达式,表达式就需要运算符
is null
is not null
<=>安全相等????专用于判断null,只适用于MySQL SQL Server不适用
between
????between m and n
????介于m与n之间(包含m与n)
in
like
????%????????表示当前位置及其后所有的字符
????_????????只表示当前位置的字符
首先明确:计算机数据存储磁盘,运算在内存中。
where就是将存储磁盘中的数据,读取到内存,并根据条件进行筛选。如果省略where,则表示所在记录都匹配
图解:
?
????作用是根据group by的条件进行分组,就是一个大的结果集,划分为多个小区域,再进行统计。
简单分组:
说明:
????group by虽然是分组的意义,但group by 更重要的作用是对大的结果集中的小区域进行统计。
更改分组排序
示例:
需求,每一组中价格最高的商品
错误示例:由于order by 是根据 group by之后的结果再行排序,
解决办法,在分组之前就对原数据进行排序。
????group by 最主要的作用是对分组的小区域进行统计
count();
统计显示结果中记录数
语法:
????count(*|字段名);
说明:
????*:表示统计所有的记录数
????字段名:根据字段名进行统计记录数
?
示例1:
示例:
????
max();
????统计最大值
示例:
min();
????统计最小值
示例:
avg();
????统计平均值
示例:
sum();
????统计和
示例:
分组统计:
示例1:
示例2:
????group by可以对多字段进行分组
语法:
????group by 字段1,字段2;
说明:
????先使用字段1对结果集进行分组,再使用字段2在分组的结果中再进行分组。有几个字段相当于分了几层。
示例:
图解:
对多字段进行分组并统计时,统计函数是应用在最小组
示例:
????使用汇总,对多个字段进行分组时所产生的多个层级的组,由里向外再应用统计函数。
示例:
原理图:
作用:
????对group by分组后的结果再进行筛选。
?
where能够实现的having也能够实现,但是having能实现的,where不一定能实现
示例:
where 的效率高于having。
having可以使用统计函数,但是where不可以使用统计函数。
说明:
????统计函数是对分组后的数据进行再次统计。在where执行过程中,结果集还没有完成生成,所以无法应用统计函数。
?
按指定的字段对数据进行排序
asc????????升序
desc????降序
????限制数据的操作(显示、更新、删除)
?
????外键,就是外面的键。
????为了某种需求,表A中的某个字段是表B中的主键,那么该字段叫表B的外键。
需求,有两个表,学生表与班级表,学生与班级有关系。如下:
虽然两个表建立关系,但并没有实质的约束存在,如下:
为了解决此种问题,必须使用外键约束。
条件:
????前提外键所附属的表必须先存在
????外键字段必须所附属表的主键
????字段的类型一定要相同。
语法1:在创建表时创建外键。
????foreign key(字段) references 表名(字段名)
示例:
语法2:通过修改表结构,创建外键
show create table 表名;
示例:
语法:
????alter table 表名 drop foreign key 外键名;
示例:
1、向class插入数据
2、向stu表中插入数据
class为主表,stu为从表
1、对主表的数据进行操作时(update与delete),不能违反外键约束。
示例:
2、如果主表与从表建立了外键约束,那么主表不能被删除
示例:
向从表中插入数据时,外键字段,必须是主表中主键字段已有的数据。
????on delete set null
????当删除主表中的记录时,从表中与之有关联的记录的外键自动设置为null
????on update cascade
????当对主表中的记录的主键字段进行更改时,从表中的与之关联的外键同步更新。
示例:
????添加置空与级联约束
添加数据:
insert into stu values(default,‘php007‘,‘lisi‘,30,‘cls001‘);
insert into stu values(default,‘php008‘,‘wang‘,30,‘cls002‘);
insert into stu values(default,‘php009‘,‘zhao‘,30,‘cls003‘);
insert into stu values(default,‘php009‘,‘zhao‘,30,‘cls001‘);
尝试删除与更新
标签:
原文地址:http://www.cnblogs.com/nyxd/p/5357045.html