笔试题练习1

1. 通常所说的web应用程序分3层,即MVC,如果我想分四层,应该怎么分?
    
加一个Hibernate数据持久层 

2. .用过Hibernate吗,用它有什么好处?
   Hibernate
的最大的好处就是简化数据库的操作,允许你的代码以对象模式来访问数据库内容。
    比如通常我们找一个User的资料需要select出所需要的资料,而通过hibnate我们可以把这个User的资料作为一个对象来看待
   
,通过User.getName()或者User.getId()等操作来获得,这样就完全统一了上层JAVA或者C#OO语言中对于数据库的非OO操作的不和谐了.
   
另外对于复杂的表和表之间的关联我们也不用去使用复杂的SelectSQL来操作,而使用对象可以方便获得,
   
比如多对多关系某用户属于的部门的名称,虽然底层数据库使用了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   对业务熟悉的开发人员可开发业务层,而其它开发人员可开发控制层。
  c.  有利于组件的重用
   
分层后更有利于组件的重用。如控制层可独立成一个能用的组件,视图层也可做成通用的操作界面
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 中对应的是什么?
  
表空间
10. 如果 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> ,获取方法同上
  
说明:传值的方法有很多种,以上是最常用最简单的几种方式 , 当然,如果传的值有中文的话,需另做处理
13. SQLServer 中左联接查询用 left join Oracle 中用什么?
  
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 表中得到匹配的部门号,这个员工的记录都将被显示。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值