昨天去一个公司面试,要求就是Delphi两年,精通MSSQL!到了公司与一个项目经理一翻“技术交流”,感觉在一些细节上,还是有一些差距!
其中,关于MSSQL,自认为,用过4年多,不说精通,但是比较熟悉,但是还是被他的一些问题问的不知所措!
其一,建一个JOB用什么SQL命令,听着他说话的语气,估计不是这种create job ...,呵,sp _ add _ job应该是正解!!虽然平时也用JOB,不太常用,用的时候大部分采用IDE(Enterprise Manager)做了,如果需要用SQL做的时候,HELP,或是GOOGLE还是能帮助解决问题!但是还是觉得细节的地方注意的不多!
其二,关于触发器的工作原理,平时用触发器的地方还蛮多的,但是具体的原理还是不是太清楚!正解应该是:
每个触发器有两个特殊的表:插入表和删除表。这两个表是逻辑表,并且这两个表是由系统管理的,存储在内存中,不是存储在数据库中,因此不允许用户直接对其修改。这两个表的结构总是与被该触发器作用的表有相同的表结构。这两个表是动态驻留在内存中的,当触发器工作完成,这两个表也被删除。这两个表主要保存因用户操作而被影响到的原数据值或新数据值。另外,这两个表是只读的,即用户不能向这两个表写入内容,但可以引用表中的数据。例如可用如下语句查看DELETED 表中的信息: |
以上,是主要的几个方面,感觉在以后的CODING中,一些小的细节的地方应该注意!!
接下来的笔试(比较讨厌笔试)
一些毛虎又让自己感觉,工作中应该注意细节!
procedure a();
var vEdit: TEdit;
begin
vEdit.caption := 'aaaa';
ShowMessage('bbbb');
end;
运行结果是?我当时还想,为啥出这个题呢!!后来想到了是vEdit的问题,看来自己真的很毛虎
其它的一些没有什么深度,数据库的一些操作,insert ,update delete ,order by , select top ,group by ,having
自己的工作经验挺长的了,但对一些小的地方,一些细节的地方还是做的不好,以后要加强