http://blog.sina.com.cn/itclan[订阅]
个人资料
分类
    内容读取中…
评论
读取中...
好友
读取中...
博文
每次我们在使用查询分析器调试SQL语句的时候,通常会看到一些信息,提醒我们当前有多少个行受到了影响,这是些什么信息?在我们调用的时候这些信息有用吗?是否可以关闭呢? 

答案是这些信息在我们的客户端的应用程序中是没有用的,这些信息是存储过程中的每个语句的DONE_IN_PROC 信息。 

我们可以利用SET NOCOUNT 来控制这些信息,以达到提高程序性能的目的。 

MSDN中帮助如下: 
  
SET NOCOUNT 
使返回的结果中不包含有关受 Transact-SQL 语句影响的行数的信息。 

语法 
SET NOCOUNT ON OFF 

注释 
当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数)。当 SET NOCOUNT 为 OFF 时,返回计数。 

即使当 SET NOCOUNT 为 ON 时,也更新 @@ROWCOUNT 函数。 

当 SET&
sql server数据类型(2009-11-08 21:53)
SQL SERVER 数据类型详解
2005-2-28 18:33:41  作者:模板天下收集整理  来源:未知 网友评论 0 条 论坛
数据类型
类型
描             
bit
整型
bit 数据类型是整型,其值只能是0、1或空值。这种数据类型用于存储只有两种可能值的数据,如Yes 或No、True 或Fa lse 、On 或Off
int
整型
int 数据类型可以存储从- 231(-2147483648)到231 (2147483 647)之间的整数。存储到数据库的几
    将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来, 那么以后要叫数据库提供与已定义好的存储过程的功能相同的服务时,只需调用execute,即可自动完成命令。

存储过程的优点

    1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
    2.当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
    3.存储过程可以重复使用,可减少数据库开发人员的工作量
    4.安全性高,可设定只有某此用户才具有对指定存储过程的使用权

先看一个最简单的存储过程

 

使用BeanFactory从xml配置文件加载bean:
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.FileSystemResource;

public class XmlConfigWithBeanFactory {

struts2结果类型(2009-10-29 22:26)

视图结果类型
struts2-core-2.0.11.2.jar根目录下的struts-default.xml中配置了struts2提供的一系列结果类型
struts2的结果类型实现了com.opensymphony.xwork2.Result接口
type支持的结果类型:

chain:用来处理Action链
chart:整合JFreeChart的结果类型
dispatcher:用来转向页面,通常处理JSP
freemaker:处理FreeMarker模板
httpheader:控制特殊HTTP行为的结果类型
jasper:用于JasperReports整合的结果类型
jsf:JSF整合的结果类型
redirect:重定向到一个URL
redirect-action:重定向到一个Action
stream:向浏览器发送InputSream对象,通常用来处理文件下载,还可用于返回AJAX数据
tiles:与Tiles整合的结果类型
velocity:处理Velocity模板
xslt:处理XML/XLST模板
plaintext:显示原始文件内容,例如文件源代码


dispatcher 结果类型为缺省的result类型,用于返回一个视图资源(如:jsp)
Xml代码 :

<result name='success'>/main.jsp</result>
&

先看看下面几个类,然后判断它们的输出
public class A {

    static{
        System.out.print(1);
    }
    public A(){
        System.out.print(2);
    }
}

public class B extends A{

    static{
        System.out.print('a');
    }
    public B(){
        System.out.print('b');
    }
}

public class C {

    public static void main(String[] args){
        A a = new B();
        a = new B();
    }
}
----------------------------------------------------------------------------------------------

Hibernate的检索方式

1'导航对象图检索方式。通过已经加载的对象,调用.iterator()方法可以得到order对象

如果是首次执行此方法,Hib会从数据库加载关联的order对象,否则就从缓存中得到。

2'OID检索方式。通过session的get,load方法知道了OID的情况下可以使用

3'HQL检索方式。使用面向对象的HQL查询语句session的find方法利用HQL来查询

4'QBC检索方式。利用QBCAPI来检索它是封装了基于字符串的查询语句

5'本地的SQL检索方式。使用本地数据库的SQL查询语句Hib会负责把检索到的JDBC结果集映射为持久化对象图。

五种检索方式的使用场合和特点:

HQL : 是面向对象的查询语言,同SQL有些相似是Hib中最常用的方式。

       查询设定各种查询条件。

       支持投影查询,检索出对象的部分属性。

       支持分页查询,允许使用having和group by

       提供内制的聚集函数,sum(),m
Spring中的Bean高级进阶(2009-10-29 09:15)
Spring中,Bean可以被定义为两种模式:单例模式和非单例模式(singleton or non-singleton)。而Spring默认的是单例模式,何谓单例模式,就是这个Bean只有一个实例存在,而不管有多少个对这个Bean的请求。而非单例模式则回在每次对这个Bean的请求中产生新的实例。简单的说就是:singleton只会被new一次,而non-singleton却在每次请求的时候都new一次。这就是区别。
上面提到,Spring中,Bean默认的模式是单例模式,我们来看看它的代码:
Java代码
HTML中meta作用(2009-10-29 07:27)

meta是用来在HTML文档中模拟HTTP协议的响应头报文。meta 标签用于网页的<head>与</head>中,meta 标签的用处很多。meta 的属性有两种:name和http-equiv。name属性主要用于描述网页,对应于content(网页内容),以便于搜索引擎机器人查找、分类(目 前几乎所有的搜索引擎都使用网上机器人自动查找meta值来给网页分类)。这其中最重要的是description(站点在搜索引擎上的描述)和 keywords(分类关键词),所以应该给每页加一个meta值。比较常用的有以下几个: 

  name 属性 

  1、<meta name='Generator' contect=''>用以说明生成工具(如Microsoft FrontPage 4.0)等; 

  2、<meta name='KEYWords' contect=''>向搜索引擎说明你的网页的关键词; 

  3、<meta name='DEscription' contect=''>告诉搜索引擎你的站点的主要内容; 

  4、<meta name='Author' contect='你的姓名'>告诉搜索引擎你的站点的制作的作者; 

  5、<meta name='Robots' contect= 'all|none|index|noindex|follow|nofollow'> 

  其中的属性说明如下

hibernate 与 ibatis 都是目前最流行的 O/R mapping 框架

hibernate 它出身于 sf.net 现在已经是 JBoss 的一部分了

ibatis 它属于 apache 下的一个子项目

hibernate 它是全封闭式的,对数据库的操作提供了完整封装,所有的SQL都是自动生成和执行,开发人员不需要再关注底层的建设,甚至不需要开发人员对SQL的熟练掌 握,所有操作都是java对象,而更注重业务逻辑,开发人员只需定义好POJO与数据库的映射(*.hbm.xml),在对数据操作时只需调用 hibernate 提供的方法完成数据层的操作,hibernate/OJB 会根据制定的存储逻辑,自动生成相应的SQL并调用JDBC接口完成执行

ibatis 它是半封闭式的,何为半封闭式,这相对hibernate 对比,ibatis的着力点则在于POJO与SQL之间的映射关系,所有的SQL都需要开发人员在映射文件编写,通过这个映射文件的配置,将SQL所需要 的参数传入进去和返回的结果字段映射到指定的POJO,而且ibatis最好的一个亮点在于可以操作存储过程。

二者的对比:
1.  iBATIS非常简单易学,Hibernate相对较复杂,门槛较高。
2.  二者都是比较优秀的开源产品
3.  当系统属于二次开发,无法对数据库结构做到控制和修改,那