数据库sql实战(61题)自我整理

一、关于查找

基本SQL: 
select [name1,n2...*] from 表名 where 条件;

###查找出现次数###
--查找字符串'10,A,B' 中逗号','出现的次数cnt
--select (length('10,A,B')-length(replace('10,A,B',',','')))as cnt;
######

###查询按照字段最后两个字母排序###
--获取tablename1中的name1,查询按照name1最后两个字母,按照升序进行排列
--select name1 from tablename1 order by substr(name1,length(name1)-1);
######

###eg:选择查找###
select e.emp_no,e.first_name,e.last_name,b.btype,s.salary,
(case b.btype
when 1 then s.salary*0.1
when 2 then s.salary*0.2
else s.salary*0.3 end) as bonus
from employees e inner join emp_bonus b on e.emp_no=b.emp_no inner join salaries s on
s.emp_no=e.emp_no and s.to_date = '9999-01-01';
######

二、关于函数

取最大:max    --max(name1)
                        --max(date1)--取最晚日期

取最小:min     --min(id)

计数:count     --count(name1)
                        --count(name1) as t

累加:sum        --sum(t1.salary1)

###group by###
group by  --group by [salary1(以其为基准分组,每组显示算一个数据)] order by salary desc;--相同数据只显示一次,降序排序
######
###having--存在###
having      --group by [name1] having t>15;--每组中存在t>15的情况;
                 --group by category_id having count(film_id) >= 5) as cc,
######

去重复:distinct   --count(distinct name1) as t;

取平均数:avg     --avg(salary1) as avg1;

###时间函数###
在sqlite中获取datetime时间对应的年份函数为strftime('%Y', to_date)
strftime:  --from tablename1 t1,tablename1 t2
                  where strftime('%Y',s2.to_date) - strftime('%Y',s1.to_date) = 1
               --每年
######

查看执行计划
explain     --explain select * from tablename1;


###替换###
replace
--replace into tablename1 values('x', 'xxxxx', 'xxxxxxxxx', 'xxxx-xx-xx', 'xxxx-xx-xx');
--将name_id(主键)=x以及name2=xxxxx的行数据替换成name_id=x以及name2=yyyyy,其他数据保持不变,使用replace实现。
######


汇总:group_concat
--select group_cancat(name1) from tablename1 group by name1;

三、关于排序

降序:desc  --order by name1 desc;
                   --order by name1 desc limit 2,1;

###limit###
limit m,n    --表示从第m+1条开始,取n条数据;
linit  n        --表示从第0条开始,取n条数据,是limit(0,n)的缩写
######

升序:asc  --order by name1 asc;
                 --order by t1.salary1 desc,t1.name1 asc;

四、关于代替

as:     --tablename as t   ==   tablename t
         --t1.name1 as n1

五、关于连接

内连接:以两表共同的列名为基准,建立基准中相同数据的数据集
inner join   --tablename1 t1 inner join tablename2 t2 on t1.name=t2.name;

左连接:以两表共同的列名为基准,建立基准中相同数据的数据集,但包括左表全部数据
left join      --tablename1 t1 left join tablename2 t2 on t1.name=t2.name;

六、关于存在

is null(为空)   --where n1.name1 is null;

not in(不存在)  --where salary1 not in (select max(salary1) from tablename1);

not exists(不存在) --where not exists (...);

<>/!=(不等于)    --where t1.name <>/!= t2.name

like-模糊查询      --where t1.name1 like '%xxxx%';

七、关于分组

group by  --group by name1;

八、关于符号

%    --where name1 %2 = 1;
''     --where name1 != 'xxxx';
-     --select max(salary1)-min(salary1) as growth
<= --where t1.salary1 <= t2.salary2

拼接:
||""||     --select name1||" "||name2 from tablename1;--拼接name1和name2中间以一个空格区分

九、关于创建

创建表:
基本语句:
create table tablename
(    
      id1 smallint(5) not null,
      name1 varchar(45) not null,
      name2  varchar(45) not null,
      name3 int not null,
      name4 datetime not null,
      time1 timestamp not null default(datetime('now','localtime')),
      --最后更新时间,默认是系统的当前时间
      primary key(id1),
      --创建外键约束
      foreign key(name1) references tablename2(name0)
);

###增加一列###
--增加一列名字为name1, 类型为datetime, NOT NULL,默认值为'0000 00:00:00'
alter table tablename1 add column name1 datetime not null default '0000-00-00 00:00:00';
######

###更改表名###
alter table tablename1 rename to tablename_new;
######


创建索引:
基本语句:
create unigue index index_name1 on tablename1(name1);
--对name1创建唯一索引index_name1

create index index_name2 on tablename2(name2);
--对name2创建普通索引index_name2

###通过索引查询###
--针对tablename1表name1字段创建索引index_name1,查询name1为xxxxx, 使用强制索引

create index index_name1 tablename1(name1);

select * from tablename1 indexed by index_name1 where name1 = 'xxxxx';
######



创建视图
基本语句:
create view name_view (name1_v,name2_v) as
select name1,name2 from tablename;
--针对tablename表创建name_view,只包含name1以及name2两列,
   并对这两列重命名,分别为name1_v,name2_v;

创建触发器
基本语句:
create trigger name1_log after insert on tablename1
begin
        insert into tablename2 values(new.id,new.name);
end;

--构造一个触发器name_log,在向tablename1表中插入一条数据的时候,触发插入相关的数据到tablename2中。


###sql生成###
--针对库中的所有表生成select count(*)对应的SQL语句
--SELECT "select count(*) from " || name || ";" AS cnts
   FROM sqlite_master WHERE type = 'table'
######

十、关于插入

基本语句:
insert into tablename
values(x,'xxxxxxxx','xxxxxxx','xxxx-xx-xx xx:xx:xx'),
(y,'yyyy','yyyyyyyy','yyyy-yy-yy yy:yy:yy');

insert or ignore into tablename values(xxx);
--如果数据已经存在,请忽略,不使用replace操作

insert into tablename1 select name1,name2 from tablename2;
--将tablename2表中的name1,name2所有数据导入tablename1表中;

十一、关于删除

基本语句:

delete from tablename1 where ......;

###删除表###
drop table tablename;
######

十二、关于更新

基本语句:
update tablename set name1 = null,name2 = 'xxxx',salary1 = salary1*1.1 where name1 = 'xxxx';
#SQL Server#
全部评论
点赞 回复 分享
发布于 2020-03-13 09:18
收藏了
点赞 回复 分享
发布于 2020-03-13 09:49
m
点赞 回复 分享
发布于 2020-03-13 14:44
truncate table tablename与delete from tablename删除表的全部信息不同,前者id重置,后者id继续
点赞 回复 分享
发布于 2020-04-23 17:08

相关推荐

不愿透露姓名的神秘牛友
01-17 17:00
点赞 评论 收藏
分享
2024-11-27 16:15
合肥工业大学 Java
点赞 评论 收藏
分享
黑皮白袜臭脚体育生:简历统一按使用了什么技术实现了什么功能解决了什么问题或提升了什么性能指标来写,要么不加头像,加了就用本人照片,这个照片显得不太正式
点赞 评论 收藏
分享
评论
5
97
分享

创作者周榜

更多
牛客网
牛客企业服务