⑴ sql面试题
1.
select
s.title,
count(p.id)
from
书表
s
left
join
评论
p
on
s.id=p.书表中的id
group
by
s.title
(注意:左外连接的作用是将评价数为0的书显示出来.count(p.id)和count(*)的区别是count(p.id)不计入p.id为null的行)
2.
select
top
1
s.title,
count(p.id)
from
书表
s
left
join
评论
p
on
s.id=p.书表中的id
group
by
s.title
order
by
2
desc
(以第2列倒序排序,取第1行)
⑵ 一个新手面试 Linux 运维工作至少需要知道哪些知识
忘记了在哪儿摘的,我一直保存着:
1、linux系统基础,这个不用说了,是基础中的基础,连这个都不会就别干了,参考书籍,可以看鸟哥linux基础篇,至少要掌握这书60%内容,没必须全部掌握,但基本命令总得会吧
2、网络服务,服务有很多种,每间公司都会用到不同的,但基础的服务肯定要掌握,如FTP, DNS,SAMBA, 邮件, 这几个大概学一下就行,LAMP和LNMP是必须要熟练,我所指的不是光光会搭建,而是要很熟悉里面的相当配置才行,因为公司最关键的绝对是WEB服务器,所以nginx和apache要熟悉,特别是nginx一定要很熟悉才行,至少有些公司还会用tomcat,这个也最好学一下。其实网络服务方面不用太担心,一般公司的环境都已经搭建好,就算有新服务器或让你整改,公司会有相应的文档让你参照来弄,不会让你乱来的,但至少相关的配置一定要学熟,而且肯定是编译安装多,那些模块要熟悉一下他的作用,特别是PHP那些模块。
这面2点只是基础,也是必要条件,不能说是工具,下以才是真正的要掌握的工具。
3、shell脚本和另一个脚本语言,shell是运维人员必须具备的,不懂这个连入职都不行,至少也要写出一些系统管理脚本,最简单也得写个监控CPU,内存比率的脚本吧,这是最最最基本了,别以为会写那些猜数字和计算什么数的,这些没什么作用,只作学习意义,写系统脚本才是最有意义,而另一个脚本语言是可选的,一般是3P,即python, perl和php,php就不需要考虑了,除非你要做开发,我个人建议学python会比较好,难实现自动化运维,perl是文本处理很强大,反正这两个学一个就行了。
4、sed和awk工具,必须要掌握,在掌握这两个工具同时,还要掌握正则表达式,这个就痛苦了,正则是最难学的表达式,但结合到sed和awk中会很强大,在处理文本内容和过滤WEB内容时十分有用,不过在学shell的同时一般会经常结合用到的,所以学第3点就会顺便学第4点。
5、文本处理命令,sort , tr , cut, paste, uniq, tee等,必学,也是结合第3点时一并学习的。
6、数据库,首选mysql,别问我为什么不学sqlserver和oracle,因为linux用得最多绝对是mysql,增删改查必学,特别要学熟查,其它方面可能不太需要,因为运维人员使用最多还是查,哪些优化和开发语句不会让你弄的。
7、防火墙,不学不行,防火墙也算是个难点,说难不难,说易不易,最重要弄懂规则,如果学过CCNA的朋友可能会比较好学,因为iptables也有NAT表,原理是一样的,而FILTER表用得最多,反正不学就肯定不合格。
8、监控工具,十分十分重要,我个人建议,最好学这3个,cacti,nagios,zibbix,企业用得最多应该是nagios和 zibbix,反正都学吧,但nagios会有点难,因为会涉及到用脚本写自动监控,那个地方很难。
9、集群和热备,这个很重要,肯定要懂的,但到了公司就不会让你去弄,因为新手基本不让你碰,集群工具有很多,最好学是LVS,这是必学,最好也学学nginx集群,反向代理,还有热备,这个就更多工具能实现了,像我公司是自己开发热备工具的,mysql热备也要学,就是主从复制,这个别告诉我容易,其实不容易的,要学懂整个流程一点也不容易,只照着做根本没意思。
10、数据备份,不学不行,工具有很多,但至少要把RAID的原理弄懂,特别是企业最常用的1+0或0+1,自己做实验也要弄出来,备份工具有很多,如tar, mp, rsync等,最好多了解一下。
算了,说到这10点已经够你受了,应该可以入门了,因为有些技术会比较难学,例如apache和nginx中还有些很重要的技术,如系统调优和服务优化,还有程序优化,这些在没接触工作前很难学习到的,所以先把这10点学了吧,估计要学熟至少3个月不止,就脚本那部分已经让你很吃力了,我建议是先学熟shell,等工作后再学另一门脚本语言,这样会比较好。
⑶ 面试题目(sql)
1、忍不住想说一句,因为第一题中的字段类型是
【日期型】,而各种数据库操作日期型数据有不同的方法,没有一种共通的方法,所以脱离了数据库而言没有一种共通的sql。
2、select
ID,NAME,ADDRESS,PHONE,LOGDATE
from
T
where
ID
in(
select
ID
from
T
group
by
NAME
having
count(*)>1)
order
by
NAME;
3、delete
from
T
where
ID
not
in
(select
min(id)
from
T
group
by
name);
4、update
T
set
T.ADDRESS=(select
E.ADDRESS
from
E
where
E.NAME=T.NAME),
T.PHONE=(select
E.PHONE
from
E
where
E.NAME=T.NAME);
5、这个不同的数据库也有不同的处理方法,不能脱离数据库谈了。
如:SqlServer或者access可以使用
top
oracle可以使用
rownum
等
---
以上,希望对你有所帮助。
⑷ 怎么才叫会使用sqlserver 面试的时候会问SQLserver和orecal等,都有些什么问
相关问题没有一个规范,主要决定于用人单位工作要求。
数据库及表格操作,和一些基本的服务器的操作,是一定需要掌握的。
⑸ sqlserver数据库知识难点
1、数据分页输出
2、事务,事务节点、保存与回滚
3、存储过程高效
4、分布式部署
5、分区存储
6、高可用,数据库镜像
⑹ 有关SQL的面试题。。。
1:
〔车辆〕、〔站台〕、〔行车路线〕最少3个表
〔车辆〕表字段〔ID〕,〔名称〕
〔站台〕表字段〔ID〕,〔名称〕,〔描述〕
〔行车路线〕表字段〔ID〕,〔车ID〕,〔站ID〕
查询:
SELECT 〔车辆〕.〔名称〕,〔站台〕.〔名称〕
FROM 〔车辆〕 INNER JOIN 〔行车路线〕
ON 〔车辆〕.〔ID〕=〔行车路线〕.〔车ID〕
INNER JOIN 〔站台〕
ON 〔站台〕.〔ID〕=〔行车路线〕.〔站ID〕
WHERE 〔站台〕.〔名称〕 = '车站1'
OR 〔站台〕.〔名称〕 = '车站2'
2:数据库设计
〔部门〕表:ID,父级ID,名称
〔员工〕表:ID,父级ID,名称,权限
〔员工所属部门〕表:ID,员工ID,部门ID
〔申请〕表:ID,内容,申请人ID,审核人ID,审核结果,备注
系统设计:
1 员工进入申请页面时,根据〔员工〕的权限来判断是否能进入
2 员工查询〔申请〕表,通过申请人ID过滤,只有申请权限
3 经理查询〔申请〕表,通过〔员工〕表查申请人的父级ID过滤,可以进行审批操作
⑺ 帮帮忙,sql面试题
如果是SqlServer 2005 的话可以这样写
select * from (
select id,name,sal,
rank() over( PARTITION BY month order by sal) as [分组排名]
from 表名)a where 分组排名 <6
人家要的是每月的前五
--------------------------------------------------
declare @ysj_month varchar(max)
declare ysj_cursor Cursor For
select distinct month from table
open ysj_cursor
while @@fetch_status =0
begin
fetch next from ysj_cursor into @ysj_month
select top 5 * from table where month = @ysj_month order by money desc
end;
CLOSE ysj_cursor
----------------------------------
declare @月份 smallint
declare @月份max smallint
set @月份=1
set @月份max=max(month)
while @月份<=@月份max
begin
select top 5 * from table where month = @ysj_month order by money desc
set @月份=@月份+1
end
⑻ SQL面试题,谢谢,麻烦了
1 select to_char(regdate,'yyyymm'),count(*) from a group by to_char(regdate,'yyyymm');
2 select name,count(*) from a group by name;
3 insert into c select id,name from a where name in (select name from a group by name having count(*)>1);
4 select * from a, (select name,max(regdate) from a group by name ) as d where a.name=d.name and a.regdate=d.regdate
这里用to_char了,说明是oracle库,LS的那是sqlserver的查法
⑼ 急--sqlserver查询问题
少有的聪明的提问题者,你一定会得到最准确的答复
SELECT RQ,SUM(CASE WHEN SHENGFU='胜' then 1 else 0 end) as 胜,
SUM(CASE WHEN SHENGFU='负' then 1 else 0 end) as 负
from #tmp group by rq