1. 通常所说的web应用程序分3层,即MVC,如果我想分四层,应该怎么分?
加一个Hibernate数据持久层
2. .用过Hibernate吗,用它有什么好处?
Hibernate的最大的好处就是简化数据库的操作,允许你的代码以对象模式来访问数据库内容。
比如通常我们找一个User的资料需要select出所需要的资料,而通过hibnate我们可以把这个User的资料作为一个对象来看待
,通过User.getName()或者User.getId()等操作来获得,这样就完全统一了上层JAVA或者C#等OO语言中对于数据库的非OO操作的不和谐了.
另外对于复杂的表和表之间的关联我们也不用去使用复杂的Select等SQL来操作,而使用对象可以方便获得,
比如多对多关系某用户属于的部门的名称,虽然底层数据库使用了3个表的主键关联操作,
但是我们可以通过User.getDep().getName()来简单的获得,这个就是持久化对象的好处了
3.在struts中,假设有一个对数据库中一张表的增删改查的操作,你是写一个action还是写多个action?为什么?
写一个action,让这个action继承自DispatchAction,然后在struts-config.xml中给这个action映射加一参数,parameter="method"
这个在提交到这个action中时,会根据传来的参数中method的值来执行相应的action的方法,比如,http://localhost:8080/login.do?method=doLogin
这个提交到action的时会自动找方法名叫doLogin的方法,参数返回值原来一样ActionForward 。
4. 为什么要用MVC?我从JSP页面直接访问数据库不是更简单吗,为什么非要先提交到控制再做处理?
a. MVC各施其职,互不干涉
在MVC模式中,三个层各施其职,所以如果一旦哪一层的需求发生了变化, 就只需要更改相应的层中的代码而不会影响到其它层中的代码。
b. 在 MVC 模式中,由于按层把系统开,那么就能更好的实现开发中的分工。网页设计人员可以进行开发视图层中的 JSP , 对业务熟悉的开发人员可开发业务层,而其它开发人员可开发控制层。
分层后更有利于组件的重用。如控制层可独立成一个能用的组件,视图层也可做成通用的操作界面
5. .Hibernate 中:不看数据库,不看 XML 文件,不看查询语句,怎么样能知道表结构?
依照对象类文件。看表结构对应的类文件,比如 UserInfo 表对应的 UserInfo.java 文件 .
6. .jsp 和 servlet 有什么区别?
a:servlet 是在 java 代码里面放 html,jsp 是在 html 里面放 java 代码 ( 最后运行的时候服务器会把 JSP 解析成 servlet)
b:servlet 是一个 java 类,有自己的映射 , 而 jsp 不是
说明:区别太多,请参考 http://00000000.net.cn/200606/200606097/97681.htm
7. 有三个页面, a.jsp,b.jsp 和 c.jsp, 流程是: a.jsp->b.jsp->c.jsp, 其中 a.jsp 中提交的数据要在 c.jsp 中访问,用最简单的方法 怎么做?注意不能放在 session 里
用隐藏表单域,即在 b.jsp 页面中用 N 个 hidden 把上一页面提交过来的信息保存下来,然后和当前一起提交 , 再到 c.jsp 里面获取
说明:尽量不要用 session 和少用 session
8. 你怎么理解 MVC 模式?
MVC 是 SUN 早期提出的 model2 开发模式 , 强制的把视图控制和模型层分开
不仅实现了功能模块和显示模块的分离,同时它还提高了应用系统的可维护性、可扩展性、可移植性和组件的可复用性
9. SQLServer 中的数据库,在 Oracle 中对应的是什么?
表空间
在 Oracle 中建一个用户 , 对应两个表空间
11. 映射是什么?你怎么理解映射?
映射即别名,通过别名可以访问
12. 有两个页面 a.jsp 和 b.jsp ,要从 a.jsp 传值到 b.jsp 有几种方法?分别是什么?
a: 最常用的方法是用 form 中的 text,<input type=text name=username value=admin> ,然后在 b.jsp 页面中这样获取
String username=request.getParameter("username");
b: 直接在 Url 地址栏里面输入第一个页面的地址,在后加问号,然后把要传的参数及值写在后面,如有多个用 & 隔开,然后在下一页面用
request.getParameter(" 参数名 ") 来获取,例如: http://localhost:8080/a.jsp?username=admin&password=111
在 b.jsp 中可用这样获取 :String username=request.getParameter("username");String username=request.getParameter("password");
c: 在 form 中放 hidden ,如 :<input type=hidden name=username value=admin> ,获取方法同上
说明:传值的方法有很多种,以上是最常用最简单的几种方式 , 当然,如果传的值有中文的话,需另做处理
在 Oracle PL-SQL 中,左连接和右连接可以用如下的方式实现:
语句片断:
SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid(+) = Department.deptid 此 SQL 文使用了右连接,即 “(+)” 所在位置的另一侧为连接的方向,右连接说明等号右侧的所有记录均会被显示,无论其在左侧是否得到匹配,也就是说上例中无论会不会出现某个部门没有一个员工的情况,这个部门的名字都会在查询结果中出现。
相反的情况:
SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid = Department.deptid(+) 则是左连接,无论这个员工有没有一个能在 Department 表中得到匹配的部门号,这个员工的记录都将被显示。