1.插入或替换记录,如果存在则先删除再插入,不存在则直接插入
replace into 表名 values
实例:replace into emp(id,ename,age,job,add_time) values(‘5‘,‘you‘,34,‘waiter‘,now());//insert语句替换为replace,其它不变
2.插入或更新记录,插入一条记录,如果该记录存在则更新
INSERT INTO ... ON DUPLICATE KEY UPDATE ...
实例:insert into emp(id,ename,age,job,add_time) values(6,‘sfd‘,12,‘model‘,now()) on duplicate key update ename=‘jj‘,age=255;
3.插入或忽略,如果我们插入一条记录,如果记录已存在就啥也不干忽略。
insert ignore into 表名 values
实例:insert ignore into emp(id,ename,age,job,add_time) values(7,‘fff‘,12,‘model‘,now()) ;
4.快照
create table tablename select * from tablename
实例:create table emp_tmp select * from emp where id=‘5‘;
新表跟旧表 表结构一致,数据根据查询条件来。
5.插入查询结果集
insert into select
实例:insert into emp_tmp(ename,age) select ename,age from emp where ename=‘you‘;
6.强制使用索引
数据库查询优化器通常会分析sql语句采用最合适的索引,但这不是绝对的,不一定总能使用最优索引,如果我们很清楚最优索引,那么可以强制使用
select * from 表名 force index(索引名) where
实例:select * from emp force index(index_age) where age=12 order by age desc;