hibernate的缓存机制的如何设置的问题?

碰到这样一个业务场景,从hibernate中取出一个类,然后更改了这个类的某些字段,然后执行了另外一个数据库操作,结果hibernate会把改变过的那个类一起保存到数据库了。怀疑是hibernate数据库的缓存里持久化了这个类,在执行其他数据库操作的时候一起提交了改变。但是奇怪的是业务类里面只有两个类有这种情况,其他类却没有出现这种情况,让人非常困惑。是不是spring或者hibernate的配置会影响到这种情况?

1个回答

这个应该不是缓存的问题,而是级联策略问题。
参考:http://blog.sina.com.cn/s/blog_5dc12c490100dc6x.html

malie1981
malie1981 不是级联问题,不然太简单了。因为无论用任何的sql命令都会发生这个事情。而且只要清空hibernate的缓存立刻就没问题了。
接近 4 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
hibernate的缓存机制
hibernate的二级缓存机制
Hibernate缓存的一些问题,望大神指教。
大家都知道使用hibernate时有一级缓存(session)和二级缓存(sessionFactory),并且 知道这些缓存的一些优点,缓存数据,减少访问数据库次数,如果用户修改数据,缓存会 有应对的策略。 但我还是有一个问题,比如某一条数据已经被缓存,我不通过服务端程序直接修改数据库 里这条记录,那么服务端hibernate缓存能知道数据库数据已经改变从而做出相应的处理吗?
hibernate的缓存配置问题
hibernate的缓存已经设置好了。。。。经过测试没有问题。。。 <ehcache> <diskStore path="D:\cache" /> <defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" diskPersistent="false" diskExpiryThreadIntervalSeconds="120" /> <cache name="com.bat128.vo.db.Goods" maxElementsInMemory="800" eternal="false" overflowToDisk="false" timeToIdleSeconds="3600" timeToLiveSeconds="3600" /> </ehcache> 但是新手想问个问题。。设置缓存无非是想阻止客户频繁访问数据库造成压力。但是,适当的时候还是要刷新的。。。因此该如何配置时间间隔或者是缓存文件的大小呢。。。。 如果hibernate没有这种配置,那又该怎么办
hibernate的缓存不刷新问题
``` sql = @" select * from UserInfo ui where ui.IsBusiness<>1 and ui.Status=0 and ui.islogin<>2 and ui.[Unit] like :queryname"; ISQLQuery query = session.CreateSQLQuery(sql).AddEntity(typeof(UserInfo)); query.SetString("queryname", "%" + queryname + "%"); comList = query.SetCacheable(true).List<UserInfo>(); ``` ``` sql = @" select * from UserInfo ui where ui.IsBusiness<>1 and ui.Status=0 and ui.islogin<>2 and (ui.Faculty like :queryname or ui.[Unit] like :queryname or ui.Interests like :queryname or ui.Name like :queryname or ui.Position like :queryname )"; ISQLQuery query = session.CreateSQLQuery(sql).AddEntity(typeof(UserInfo)); query.SetString("queryname", "%" + queryname + "%"); comList = query.SetCacheable(true).List<UserInfo>(); ``` 一段代码 根据queryname查询一个大学里的人员 queryname是大学、学院等的名字 只要sql长度比较长 就不刷新缓存 这是怎么回事? Nhibernate+memcached
Spring3+hibernate4配置二级缓存的问题
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" destroy-method="destroy"> <property name="dataSource"> <ref bean="dataSource" /> </property> <property name="mappingResources"> <list> <value>com/wjh/po/AfterPostPO.hbm.xml</value> <value>com/wjh/po/LogPO.hbm.xml</value> <value>com/wjh/po/PostPO.hbm.xml</value> <value>com/wjh/po/UserPO.hbm.xml</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">false</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> <prop key="hibernate.generate_statistics">true</prop> <prop key="hibernate.cache.use_structured_entries">true</prop> <!-- <prop key="hibernate.cache.use_query_cache">true</prop> <prop key="hibernate.cache.use_second_level_cache">true</prop> <prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory </prop> <prop key="net.sf.ehcache.configurationResourceName">ehcache.xml</prop> --> </props> </property> </bean> spring3+hibernate4 配置ehcache二级缓存只要一把上面的二级缓存配置的注释部分去掉,访问直接报错,而且两次错误不一样,重启tomcat第一次访问时候报的最终错误是: java.lang.ClassNotFoundException: org.hibernate.engine.jndi.JndiNameException 再访问一次报的最终错误是: java.lang.NoClassDefFoundError: Could not initialize class org.hibernate.cache.ehcache.EhCacheRegionFactory 是在是解决不了了,网上都搜遍了,大部分是hibernate3的配置,但是hibernate4的和hibernate3的不一样,也有hibernate4的配置,但是按照他们的都不行,大神门帮帮吧 slf4j-api-1.6.1.jar,hibernate-ehcache-4.3.4.Final.jar,ehcache-core-2.4.3.jar三个包已经导入了
hibernate读取EhCache缓存的问题。
如下查询1000-2000左右的数据,有时就会报这个异常,大神们,怎么解决! 十月 20, 2017 5:40:04 下午 org.apache.catalina.core.StandardWrapperValve invoke 严重: Servlet.service() for servlet [XXXX] in context with path [] threw exception [Handler processing failed; nested exception is java.lang.NoSuchMethodError: org.hibernate.cache.CacheException: method <init> (Ljava/lang/Throwable;)V not found] with root cause java.lang.NoSuchMethodError: org.hibernate.cache.CacheException: method <init>(Ljava/lang/Throwable;)V not found at net.sf.ehcache.hibernate.EhCache.get(EhCache.java:103) at org.hibernate.cache.ReadWriteCache.get(ReadWriteCache.java:80) at org.hibernate.event.def.DefaultLoadEventListener.loadFromSecondLevelCache (DefaultLoadEventListener.java:486) at org.hibernate.event.def.DefaultLoadEventListener.doLoad(DefaultLoadEventListener.java:357) at org.hibernate.event.def.DefaultLoadEventListener.load(DefaultLoadEventListener.java:139) at org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:195) at org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:103) at org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:878) at org.hibernate.impl.SessionImpl.internalLoad(SessionImpl.java:846) at org.hibernate.type.EntityType.resolveIdentifier(EntityType.java:557) at org.hibernate.type.EntityType.resolve(EntityType.java:379) at org.hibernate.engine.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:116) at org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:842) at org.hibernate.loader.Loader.doQuery(Loader.java:717) at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:224) at org.hibernate.loader.Loader.doList(Loader.java:2211) at org.hibernate.loader.Loader.listUsingQueryCache(Loader.java:2127) at org.hibernate.loader.Loader.list(Loader.java:2087) at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:375) at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:338) at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:172) at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1121) at org.hibernate.impl.QueryImpl.list(QueryImpl.java:79) at org.hibernate.ejb.QueryImpl.getResultList(QueryImpl.java:67) at com.shopping.core.base.GenericEntityDao$2.doInJpa(GenericEntityDao.java:86) at org.springframework.orm.jpa.JpaTemplate.execute(JpaTemplate.java:184) at org.springframework.orm.jpa.JpaTemplate.execute(JpaTemplate.java:147) at com.shopping.core.base.GenericEntityDao.query(GenericEntityDao.java:71) at com.shopping.core.base.GenericDAO.query(GenericDAO.java:98) at com.shopping.foundation.service.impl.GoodsServiceImpl.query(GoodsServiceImpl.java:92) at com.shopping.foundation.service.impl.GoodsServiceImpl$$FastClassByCGLIB$$49a06392.invoke(<generated>) at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:149) at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint (Cglib2AopProxy.java:700) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed (ReflectiveMethodInvocation.java:149) at org.springframework.transaction.interceptor.TransactionInterceptor.invoke (TransactionInterceptor.java:106) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed (ReflectiveMethodInvocation.java:171) at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept (Cglib2AopProxy.java:635) at com.shopping.foundation.service.impl.GoodsServiceImpl$$EnhancerByCGLIB$$36bbd4e7.query(<generated>) at com.shopping.view.web.action.IndexViewAction.wapindex(IndexViewAction.java:839) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.doInvokeMethod (HandlerMethodInvoker.java:421) at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod (HandlerMethodInvoker.java:136) at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod (AnnotationMethodHandlerAdapter.java:326) at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle (AnnotationMethodHandlerAdapter.java:313) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:875) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:807) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:571) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:501) at javax.servlet.http.HttpServlet.service(HttpServlet.java:624) at javax.servlet.http.HttpServlet.service(HttpServlet.java:731) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at com.shopping.core.filter.ShopFilter.doFilter(ShopFilter.java:111) at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:236) at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at com.shopping.core.filter.SecondDomainFilter.doFilter(SecondDomainFilter.java:58) at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:236) at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:167) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.tuckey.web.filters.urlrewrite.RuleChain.handleRewrite(RuleChain.java:176) at org.tuckey.web.filters.urlrewrite.RuleChain.doRules(RuleChain.java:145) at org.tuckey.web.filters.urlrewrite.UrlRewriter.processRequest(UrlRewriter.java:92) at org.tuckey.web.filters.urlrewrite.UrlRewriteFilter.doFilter(UrlRewriteFilter.java:394) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:378) at org.springframework.security.intercept.web.FilterSecurityInterceptor.invoke (FilterSecurityInterceptor.java:109) at org.springframework.security.intercept.web.FilterSecurityInterceptor.doFilter (FilterSecurityInterceptor.java:83) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at org.springframework.security.intercept.web.FilterSecurityInterceptor.invoke (FilterSecurityInterceptor.java:109) at org.springframework.security.intercept.web.FilterSecurityInterceptor.doFilter (FilterSecurityInterceptor.java:83) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at org.springframework.security.ui.SessionFixationProtectionFilter.doFilterHttp (SessionFixationProtectionFilter.java:67) at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at com.shopping.core.security.support.ShopSecurityExceptionFilter.doFilterHttp (ShopSecurityExceptionFilter.java:64) at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at org.springframework.security.ui.ExceptionTranslationFilter.doFilterHttp (ExceptionTranslationFilter.java:101) at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at org.springframework.security.wrapper.SecurityContextHolderAwareRequestFilter.doFilterHttp (SecurityContextHolderAwareRequestFilter.java:91) at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at org.springframework.security.ui.AbstractProcessingFilter.doFilterHttp(AbstractProcessingFilter.java:277) at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter (FilterChainProxy.java:390) at org.springframework.security.ui.logout.LogoutFilter.doFilterHttp(LogoutFilter.java:89) at com.shopping.core.filter.NorLogoutFilter.doFilterHttp(NorLogoutFilter.java:63) at org.springframework.security.ui.SpringSecurityFilter.doFilter(SpringSecurityFilter.java:53) at org.springframework.security.util.FilterChainProxy$VirtualFilterChain.doFilter
hibernate 的缓存使用问题
问题描述见: 在测试Hibernate二级缓存的时候 把ehcache.xml和hibernate.cfg.xml里的相关二级缓存的配置 都删掉 , 直接在hbm.xml中配置 <cache usage= "read-write " /> , 发现查询结果看起来仍是通过缓存来查询的 因为sql没有打印两次 [code="java"] package com.vavi.test; import org.hibernate.Session; import com.vavi.dao.HibernateSessionFactory; import com.vavi.pojo.Tuser; public class Test { public static void main(String[] args) { Session sess = HibernateSessionFactory.getCurrentSession(); Tuser user_load = (Tuser) sess.load(com.vavi.pojo.Tuser.class, new Long(1)); System.out.println(user_load.getName()); sess.close(); sess = HibernateSessionFactory.getCurrentSession(); Tuser user_get = (Tuser) sess.get(com.vavi.pojo.Tuser.class, new Long(1)); System.out.println(user_get.getName()); sess.close(); } } [/code] HibernateSessionFactory 是MyEclipse 生成的 [b]问题补充:[/b] package com.vavi.test; /** * 结论:Session级别的缓存 仅在当前session 生命期内有效 * 一旦该session关闭 ,再次查询时仍需要访问数据库 */ import org.hibernate.Session; import com.vavi.dao.HibernateSessionFactory; import com.vavi.pojo.Tuser; public class Test_SessionClose { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Session sess = HibernateSessionFactory.getCurrentSession(); Tuser user_load =(Tuser) sess.load(com.vavi.pojo.Tuser.class, new Long(1)); System.out.println(user_load.getName()); sess.close(); sess = HibernateSessionFactory.getCurrentSession(); Tuser user_get =(Tuser) sess.get(com.vavi.pojo.Tuser.class, new Long(1)); System.out.println(user_get.getName()); sess.close(); } } 这段代码跟上面的一样 唯一 不同的地方就是 不在 Tuser.hbm.xml 加上 <cache usage="read-write" /> 这时候打印的结果是 : Hibernate: select tuser0_.ID as ID0_, tuser0_.NAME as NAME0_0_, tuser0_.AGE as AGE0_0_ from GHJ.TUSER tuser0_ where tuser0_.ID=? ghj Hibernate: select tuser0_.ID as ID0_, tuser0_.NAME as NAME0_0_, tuser0_.AGE as AGE0_0_ from GHJ.TUSER tuser0_ where tuser0_.ID=? ghj 说明session cache 还是失效了的 按照您的说法 我打印了下 System.out.println("session:"+sess); 这两个程序(加不加 <cache usage="read-write" /> )都是 session:org.hibernate.impl.SessionImpl(<closed>) 根据这个打印结果并不能看出什么 所以关键是 这段话 <cache usage="read-write" /> 不太清楚 他到底有什么作用 应该不是 一级缓存 二级缓存 或 查询缓存 最后谢谢您的解答 ^^ [b]问题补充:[/b] 多谢gotothework的 回答 你说的这几种策略我也知道 但是关键是加上这段话后 <cache usage="read-write" /> 不需要访问数据库 就可以直接出现结果了 (详细描述见上) 而我认为 这个查询结果不是 一级缓存 二级缓存 或 查询缓存 里面的内容 但是如果不是 hibernate 又是如何管理这部分缓存的 抑或还是我的理解有误? [b]问题补充:[/b] To gotothework : 在调用sess.close()这个方法以前,一级缓存是一直有效的.所以应该是由一级缓存里调用出来的. 当你查询时,会首先从一级缓存中寻找,如果查找不到,还会从二级缓存中寻找,如果还未找到,就会从数据库中查询. 我明白 你见我第二个问题补充,现在问题是 其他配置(二级缓存 查询缓存 都不配置),仅在Tuser.hbm.xml 加上 <cache usage="read-write" /> 打印结果表明: 第二次查询结果 没有访问数据库 就直接返回结果了 [b]问题补充:[/b] To gotothework : 在您说的这种情况下 hibernate是使用哪种缓存呢? 一级缓存? 但是如果同样的程序 不在 Tuser.hbm.xml 加上 <cache usage="read-write" /> 仍是需要先后访问两次数据库的 所以这段 <cache usage="read-write" /> 代码作用很诡异 难道加了这段话就保存了一级缓存的数据? 您说的openSession() 我试了下 同时加上了 sess.contains(user_load) 和hashCode() 这个方法 package com.vavi.dao; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; //import com.vavi.dao.HibernateSessionFactory; import com.vavi.pojo.Tuser; public class SFTest { public static void main(String[] args) { SessionFactory sf = new Configuration().configure().buildSessionFactory(); Session sess = sf.openSession(); System.out.println(sess.hashCode()); Tuser user_load = (Tuser) sess.load(com.vavi.pojo.Tuser.class, new Long(1)); System.out.println("sess.contains user_load? "+sess.contains(user_load)); System.out.println(user_load.getName()); sess.close(); System.out.println("sess.contains user_load? "+sess.contains(user_load)); sess =sf.openSession(); System.out.println(sess.hashCode()); Tuser user_get = (Tuser) sess.get(com.vavi.pojo.Tuser.class, new Long(1)); System.out.println("sess.contains user_load? "+sess.contains(user_load)); System.out.println("sess.contains user_get? "+sess.contains(user_get)); System.out.println(user_get.getName()); sess.close(); System.out.println("sess.contains user_get? "+sess.contains(user_get)); } } 打印结果如下: 31966667 sess.contains user_load? true Hibernate: select tuser0_.ID as ID0_, tuser0_.NAME as NAME0_0_, tuser0_.AGE as AGE0_0_ from GHJ.TUSER tuser0_ where tuser0_.ID=? ghj sess.contains user_load? false 22375698 sess.contains user_load? false sess.contains user_get? true ghj sess.contains user_get? false 所以这个现象就比较诡异了 发现sess关闭后,sess.contains(user_load)返回值是false的。 但是仍未查询数据库就获得结果了 [b]问题补充:[/b] 哈哈 问题搞定 忘了hibernate 是默认启动二级缓存 以及使用 Cache provider: org.hibernate.cache.EhCacheProvider. 我上述的问题现象其实还是使用Hibernate的 二级缓存的 [main] (SettingsFactory.java:209) - Second-level cache: enabled INFO [main] (SettingsFactory.java:213) - Query cache: disabled INFO [main] (SettingsFactory.java:321) - Cache provider: org.hibernate.cache.EhCacheProvider INFO [main] (SettingsFactory.java:228) - Optimize cache for minimal puts: disabled INFO [main] (SettingsFactory.java:237) - Structured second-level cache entries: disabled 总结: 1、使用二级缓存的话 仅仅必须在 Tuser.hbm.xml 加上 <cache usage="read-write" /> 其他设置使用的是Hibernate 里面jar包的默认配置文件 当然如果需要高级应用,那就需要自定义配置文件了 2、对于Hibernate,遇到不明白的问题,建议加上<property name="generate_statistics">true</property> 并打印debug级别日志 3、Session sess = HibernateSessionFactory.getCurrentSession(); 仍是获得新的session 实例的 同时 一级缓存(Session Cache)是在session.close() 调用后就失效的,跟当前没关系 (不知道理解有没有问题) 4、没有莫名其妙的问题,想起老大对我说的一句公告。 哈哈 ,这就是我中秋节的礼物了 ^^
mybatis缓存和hibernate缓存的理解问题和区别。类缓存和查询缓存的理解和区别
Hibernate的一级缓存的目的是为了方便管理实体类的状态(临时状态、持久化状态、游离状态、删除状态)。Hibernate的目的二级缓存是为了减少sql语句。那么mybatis的一级缓存和二级缓存的目的是为了什么? Hibernate的二级缓存通常使用ehcache,通常配置的是实体类,所以ehcache里面配置实体类是属于类缓存吗? 类缓存到底在什么地方优化?怎样减少sql语句? 查询缓存到底什么地方优化?怎么减少sql语句? 类缓存和查询缓存的区别是什么
关于Hibernate的二级缓存配置
配置二级缓存时在实体xx.hbm.xml中配置的 ``` <cache usage="read-only" include="non-lazy" region="personCache"/> ``` 关于这个include属性,我看官方文档上说all是对所有属性就行缓存,non-lazy是对不是lazy加载的属性缓存,问题是我怎么判断它到底有没有对lazy="true"的属性缓存呢?
hibernate二级缓存问题。
我把 List<Team> teams = meaulInter.executeQuery("from Team"); 这个查询出来的 结果放到了二级缓存里面。 然后这个Team对象 跟 一个 Page 对象 是1对多关系,因此,当我要引出Team对象对应的多方Page对象的属性的时候,会向数据库发出查询语句,我想把查询的结果放到缓存里面我该怎么做,才会令到懒加载的时候能从缓存中取出?
关于hibernate一级缓存问题。
hibernate的list查询会向一级缓存里面放入数据,但是下次取数据的时候,却不会再一级缓存里面取 ,怎样可以令到list查询到一级缓存里面取数据?
Hibernate二级缓存的缺点是什么。
请大家给小弟讲一下,最好举例说明,本人已经理解耳机缓存的概念。但是不知道 她为什么 对于 并发量大、频繁更新等优缺点。
hibernate整合redis二级缓存问题
背景: 有一老项目采用的hibernate配合ehcache作为二级缓存,现因需求需要更换redis来做hibernate的二级缓存。大家不用问为什么不换掉hibernate,因为是老项目所以风险太大。 问题: 1、我按照网上做法导入了若干个jar包,见图: ![图片说明](https://img-ask.csdn.net/upload/201809/12/1536736237_134115.jpg) 2、spring中sessionFactory也配置了二级缓存: ``` hibernate.cache.use_query_cache = true hibernate.cache.use_second_level_cache = true hibernate.cache.use_structured_entries = true hibernate.cache.region_prefix = hibernate hibernate.cache.region.factory_class = org.hibernate.cache.redis.hibernate5.RedisRegionFactory hibernate.cache.provider_configuration_file_resource_path = hibernate-redis.properties ``` 3、也分别创建了hibernate-redis.properties和redisson.yaml,内容分别如下 (1)hibernate-redis.properties: ``` redisson-config = classpath:redisson.yaml redis.expiryInSeconds.default = 360 redis.expiryInSeconds.hibernate.common = 0 redis.expiryInSeconds.hibernate.account = 1200 ``` (2)redisson.yaml ``` singleServerConfig: idleConnectionTimeout: 10000 pingTimeout: 5000 connectTimeout: 5000 timeout: 5000 retryAttempts: 1 retryInterval: 1000 reconnectionTimeout: 3000 failedAttempts: 1 password: 123456 subscriptionsPerConnection: 3 clientName: null address: [ "redis://127.0.0.1:6379" ] subscriptionConnectionMinimumIdleSize: 1 subscriptionConnectionPoolSize: 3 connectionMinimumIdleSize: 3 connectionPoolSize: 3 database: 0 dnsMonitoring: false dnsMonitoringInterval: 5000 threads: 0 codec: !<org.redisson.codec.SnappyCodec> {} useLinuxNativeEpoll: false eventLoopGroup: null ``` 4、redis也正常运行 5、最后运行程序报了一个错: ``` Caused by: com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.net.URI` out of START_ARRAY token at [Source: (URL); line: 14, column: 4] (through reference chain: org.redisson.config.Config["singleServerConfig"]->org.redisson.config.SingleServerConfig["address"]) at com.fasterxml.jackson.databind.exc.MismatchedInputException.from(MismatchedInputException.java:63) at com.fasterxml.jackson.databind.DeserializationContext.reportInputMismatch(DeserializationContext.java:1342) at com.fasterxml.jackson.databind.DeserializationContext.handleUnexpectedToken(DeserializationContext.java:1138) at com.fasterxml.jackson.databind.deser.std.StdDeserializer._deserializeFromArray(StdDeserializer.java:674) at com.fasterxml.jackson.databind.deser.std.FromStringDeserializer.deserialize(FromStringDeserializer.java:164) at com.fasterxml.jackson.databind.deser.impl.FieldProperty.deserializeAndSet(FieldProperty.java:136) at com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:288) at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:151) at com.fasterxml.jackson.databind.deser.impl.MethodProperty.deserializeAndSet(MethodProperty.java:127) at com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:288) at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:151) at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:4013) at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:2959) at org.redisson.config.ConfigSupport.fromYAML(ConfigSupport.java:169) at org.redisson.config.Config.fromYAML(Config.java:754) at org.hibernate.cache.redis.client.RedisClientFactory.createRedisClient(RedisClientFactory.java:63) ... 57 more ``` 不知道怎么解决了,希望有相关经验的大神能助我解惑。
hibernate中的“二级缓存”和“类集合二级缓存”有什么关系和区别?
## hibernate中的“二级缓存”和“类集合二级缓存”有什么关系和区别?请言简意骇的解释一下这两个呢,可举些小例子,谢谢作答
提问:Hibernate一级缓存的生命周期是多长?
我最近读了一本《Java Persistence with Hibernate》. 我有一个关于Hibernate的一级缓存的生命期的疑问, 书上说hibernate的一级缓存是unit of work(可能是transaction?)级别的,但是又说一个persistence context(session)内有一个一级缓存。 1.但是我不明白unit of work指的是什么,请问是transaction吗? 2.对于一级缓存,是在一个transaction结束之后就消失了,还是在一个session对象被垃圾回收之后才结束呢? 3.还有一个问题我也很困惑,就是,如果我现在的线程1的一级缓存内已经有读出来的数据,然后线程2修改了数据库的内容,那么线程1的一级缓存内的数据就和数据库的数据不一样了,这样当线程1的程序读一级缓存内的数据的时候,读出来的不就是dirty的数据了吗?这个问题应该如何解决呢? 谢谢了!:)
hibernate中关于一级缓存的问题?
在hibernate中,查询是不需要开启缓存的,但是在get或load的时候,为什么有查询了缓存,这个缓存是查询缓存还是一级缓存?
hibernate缓存失效?求教!
在学习hibernate的时候发现只要在session.createQuery("from Student").list 中加上.setFirstResult(0).setMaxResults(50) 就会发生N+1问题。 这个是我的一级缓存测试代码: HibernateUtil是把SessionFactory跟session包装起来了。 ```@Test public void Test04(){ Session session = null; try { session = HibernateUtil.getSession(); List<Student> ls = session.createQuery("select stu from Student stu ") .setFirstResult(0).setMaxResults(100).list(); Iterator<Student> stus = ls.iterator(); for(;stus.hasNext();){ Student stu = stus.next(); System.out.println(stu.getName()); } stus = session.createQuery("select stu from Student stu ").setFirstResult(0).setMaxResults(50).iterate(); while(stus.hasNext()){ Student stu = stus.next(); System.out.println(stu.getName()); } } catch (Exception e) { session.getTransaction().rollback(); e.printStackTrace(); } finally{ if(session!=null) session.close(); } } ``` 本来应该是第一句SQL结束后下面只会执行一条SQL查询到缓存里的ID,然后就输出其他数据, 但结果是每一条数据都要去查询,造成N+1问题。结果如图: ![图片说明](https://img-ask.csdn.net/upload/201702/20/1487565607_393895.png) 之后就是二级缓存也是同样的情况,(ps:就只有查询分页数据的时候有问题,其他都没问题,查询缓存我试过了。所以我就不放二级缓存的配置了。) 代码如下: ```@Test public void Test05(){ Session session = null; try { session = HibernateUtil.getSession(); List<Student> stus = session.createQuery(" from Student ") .setFirstResult(0).setMaxResults(50).list(); } catch (Exception e) { session.getTransaction().rollback(); e.printStackTrace(); } finally{ if(session!=null) session.close(); } try { session = HibernateUtil.getSession(); Iterator<Student> ls = session.createQuery("from Student") .setFirstResult(0).setMaxResults(50) .iterate(); while(ls.hasNext()){ Student stu = ls.next(); System.out.println(stu.getName()); } } catch (Exception e) { session.getTransaction().rollback(); e.printStackTrace(); } finally{ if(session!=null) session.close(); } } ``` 结果如图: ![图片说明](https://img-ask.csdn.net/upload/201702/20/1487565624_305086.png) 现在的情况是;如果我把.setMaxResults(50)去掉的话就会正常。 或者我使用了 session.createQuery("from Student").setParameter(0, "%张%").setFirstResult(0).setMaxResults(50) 的话,就又会正常运行了。只发了两条SQL, 求教大神们,高手们告之我究竟是哪里出错误?我在网上找了好多题目都找不到原因。
如何使Hibernate中EhCache缓存的Key能够动态设置
您好! 我现在在Hibernate中用EhCache做缓存,hibernate在对对象操作时自动缓存数据,但是缓存的key为对象的主键,我现在想对这个key在缓存前加上一个标识,因为我想对hibernate进行多schema扩展,所以如果用hibernate自己的缓存策略,相同的对象在schema切换后可能主键相同,那么缓存就会出现问题。求大牛帮忙下。谢谢! 伪代码描述如下: //前提,Schema1中已经缓存了主键为1的用户信息。 Session session = null; User user = null; //1、这里用Schema1创建Session,通过缓存获取主键为1的用户 session = Schema1.sessionFactory.openSession(); user = session.get(1); session.close(); //2、这里用Schema2创建Session,通过缓存获取主键为1的用户,但是 //拿出来的用户信息却是Schema1中的主键为1的用户信息,所以我想 //在hibernate进行二级缓存时,对缓存key进行操作,添加标识。 session = Schema2.sessionFactory.openSession(); user = session.get(1); session.close();
hibernate 一级缓存问题
向数据库用save 方法添加user 对象,然后清除一级缓存,再用get 方法查找这个对象,为什么能查的到?该对象在哪里存储着![图片](https://img-ask.csdn.net/upload/201706/08/1496932901_29134.jpg)
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问