十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
复制项目mymvc4,新建项目mymvc5
发展壮大离不开广大客户长期以来的信赖与支持,我们将始终秉承“诚信为本、服务至上”的服务理念,坚持“二合一”的优良服务模式,真诚服务每家企业,认真做好每个细节,不断完善自我,成就企业,实现共赢。行业涉及阳光房等,在网站建设、营销型网站、WAP手机网站、VI设计、软件开发等项目上具有丰富的设计经验。
packagecom.hy.filter; importjava.io.IOException; importjavax.servlet.Filter; importjavax.servlet.FilterChain; importjavax.servlet.FilterConfig; importjavax.servlet.ServletException; importjavax.servlet.ServletRequest; importjavax.servlet.ServletResponse; importjavax.servlet.annotation.WebFilter; importjavax.servlet.annotation.WebInitParam; importjavax.servlet.http.HttpServletRequest; importjavax.servlet.http.HttpServletResponse; importcom.hy.utils.StringUtil; @WebFilter(urlPatterns = { "*.do"}, initParams = { @WebInitParam(name = "encoding", value = "UTF-8") }) publicclassCharacterEncodingFilter implementsFilter { privateString encoding= "UTF-8"; @Override publicvoidinit(FilterConfig filterConfig) throwsServletException { String encoding= filterConfig.getInitParameter("encoding"); System.out.println("encoding="+encoding); if(StringUtil.isNotEmpty(encoding)) { this.encoding= encoding; } } @Override publicvoiddoFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throwsIOException, ServletException { HttpServletRequest request= (HttpServletRequest) req; HttpServletResponse response= (HttpServletResponse) resp; request.setCharacterEncoding(encoding); response.setCharacterEncoding(encoding); response.setContentType("text/html;charset="+encoding); chain.doFilter(request, response); return; } @Override publicvoiddestroy() { } } |
createtableworker( widintprimarykey, wnamevarchar2(20), ageint ) select* fromuser_tables; select* fromuser_col_commentswheretable_name= 'WORKER' select* fromworker; insertintoworkervalues(1,'fbb',10); commit; rollback; ##Oracle自动开启事务,但是需要手动的提交事务或回滚事务 ##mysql默认自动开启事务,自动提交事务,失败自动回滚 |
当我们需要手动提交事务,调用 conn.setAutoCommit(false); 但是,我们的conn到底用的是哪个connection?我们三个dao代码中,应该使用同一个Connection对象,才能让三个dao操作处于同一个事务。如果用面向对象的思想来写,那么我们需要在dao中传参。
事务前置到XxxFilter中,进行”所谓的”事务管理的操作。 Service还是正常的Service,不要XxxServiceImpl代码中获取Connection对象,XxxDao的方法也不要传递Connection对象。
但是如何解决三个dao操作要共享同一个Connection对象的问题呢?
有一个工厂,有三个员工 – 相当于三个dao方法。
这个纽带叫ThreadLocal