iBatis和MyBatis 中返回数据对应关系

直接进入主题,现在的项目改用MyBatis了,感觉跟iBatis还是不一样的,比如在判断空值上面,iBatis是有标签的<isNotEmpty><isNotNull>等标签使用,MyBatis确是使用<if></if>来进行这些判断的。所以区别了还是有的,就是看怎么使用方便。不过个人还是觉得MyBatis方便,因为这是面向接口的编程。现在是比较流行的。下面说说我在使用中遇到的问题。

(一):iBatis使用对应关系

iBatis中我们在查询多条数据的时候都会返回一个resultMap,那么我们查询的数据就和resultMap对应,那么有没有想过如果两边对不上会怎么样,特别是在resultMap公用的情况下,你在那边加会有什么影响等情况。

经过我的测试发现,如果查询的字段多了,resultMap对应的字段少了,不会报错,只是查询后后台取的的数据这个字段为NULL值

如果resultMap多了,查询数据的时候没有查询出来这个数据,那么此时就会报错,比如说我查询的时候没有查询name这个字段,但是resultMap里面对应的有这个字段,就会报如下错误

org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation; uncategorized SQLException for SQL []; SQL state [S0022]; error code [];
--- The error occurred in com/mouse/snow/pojo/sqlmap/User.xml.
--- The error occurred while applying a result map.
--- Check the Evaluation.get-Evaluation-list.
--- Check the result mapping for the 'name' property.
--- Cause: java.sql.SQLException: Column 'name' not found.; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:
--- The error occurred in
com/mouse/snow/pojo/sqlmap/User.xml.
--- The error occurred while applying a result map.
--- Check the Evaluation.get-User-list.
--- Check the result mapping for the 'name' property.
--- Cause: java.sql.SQLException: Column 'name' not found.

这里就说明了,resultMap里面不能多,但是查询的数据是可以多的,只是resultMap里面没有对应,此时pojo里面的数据是空值。

(二):MyBatis的使用

  在我是使用MyBatis的时候,这种对应关系谁多谁少都不会报错的,不影响。我是在使用模糊查询的时候遇到了问题,下面说说模糊查询的方式

(1):模糊查询的方式有好多的,当你传入一个单个数据模糊查询的时候,就是只传入一个keyword时候,传到*.xml里面,我每次都是使用如下

select * from t_user where id like '%${keyword}%'

当时当我这样写的时候出现了错误:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'keyword' in 'class java.lang.String'
at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:) ~[mybatis-spring-1.2..jar:1.2.]
at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:) ~[mybatis-spring-1.2..jar:1.2.]
at com.sun.proxy.$Proxy16.selectList(Unknown Source) ~[na:na]
at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:) ~[mybatis-spring-1.2..jar:1.2.]
at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:) ~[mybatis-3.2..jar:3.2.]
at com.sun.proxy.$Proxy25.selecetStationByWord(Unknown Source) ~[na:na]
at com.xpg.charge.service.impl.ChargingPileServiceImpl.selecetStationByWord(ChargingPileServiceImpl.java:) ~[ChargingPileServiceImpl.class:na]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_25]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:) ~[na:1.7.0_25]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:) ~[na:1.7.0_25]
at java.lang.reflect.Method.invoke(Method.java:) ~[na:1.7.0_25]
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.transaction.interceptor.TransactionInterceptor$.proceedWithInvocation(TransactionInterceptor.java:) ~[spring-tx-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:) ~[spring-tx-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:) ~[spring-tx-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:) ~[spring-aop-4.1..RELEASE.jar:4.1..RELEASE]
at com.sun.proxy.$Proxy28.selecetStationByWord(Unknown Source) ~[na:na]
at com.xpg.charge.controller.web.ChargingPileController.selectStationByKeyWord(ChargingPileController.java:) ~[ChargingPileController.class:na]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_25]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:) ~[na:1.7.0_25]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:) ~[na:1.7.0_25]
at java.lang.reflect.Method.invoke(Method.java:) ~[na:1.7.0_25]
at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:) ~[spring-web-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:) ~[spring-web-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:) ~[spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:) ~[spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:) ~[spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:) ~[spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:) ~[spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:) ~[spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:) [spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:) [spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at javax.servlet.http.HttpServlet.service(HttpServlet.java:) ~[servlet-api.jar:na]
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:) [spring-webmvc-4.1..RELEASE.jar:4.1..RELEASE]
at javax.servlet.http.HttpServlet.service(HttpServlet.java:) ~[servlet-api.jar:na]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:) ~[tomcat7-websocket.jar:7.0.]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.shiro.web.servlet.ProxiedFilterChain.doFilter(ProxiedFilterChain.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.AdviceFilter.executeChain(AdviceFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.AdviceFilter.doFilterInternal(AdviceFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.ProxiedFilterChain.doFilter(ProxiedFilterChain.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.AbstractShiroFilter.executeChain(AbstractShiroFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.AbstractShiroFilter$.call(AbstractShiroFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.subject.support.SubjectCallable.doCall(SubjectCallable.java:) ~[shiro-core-1.2..jar:1.2.]
at org.apache.shiro.subject.support.SubjectCallable.call(SubjectCallable.java:) ~[shiro-core-1.2..jar:1.2.]
at org.apache.shiro.subject.support.DelegatingSubject.execute(DelegatingSubject.java:) ~[shiro-core-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(AbstractShiroFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:) ~[shiro-web-1.2..jar:1.2.]
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:) ~[spring-web-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:) ~[spring-web-4.1..RELEASE.jar:4.1..RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:) ~[spring-web-4.1..RELEASE.jar:4.1..RELEASE]
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:) ~[spring-web-4.1..RELEASE.jar:4.1..RELEASE]
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:) ~[catalina.jar:7.0.]
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:) ~[catalina.jar:7.0.]
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:) ~[tomcat-coyote.jar:7.0.]
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:) ~[tomcat-coyote.jar:7.0.]
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:) ~[tomcat-coyote.jar:7.0.]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:) ~[na:1.7.0_25]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:) ~[na:1.7.0_25]
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:) ~[tomcat-coyote.jar:7.0.]
at java.lang.Thread.run(Thread.java:) ~[na:1.7.0_25]
Caused by: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'keyword' in 'class java.lang.String'
at org.apache.ibatis.reflection.Reflector.getGetInvoker(Reflector.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.reflection.MetaClass.getGetInvoker(MetaClass.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.reflection.wrapper.BeanWrapper.getBeanProperty(BeanWrapper.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.reflection.wrapper.BeanWrapper.get(BeanWrapper.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.reflection.MetaObject.getValue(MetaObject.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.DynamicContext$ContextMap.get(DynamicContext.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.DynamicContext$ContextAccessor.getProperty(DynamicContext.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.ognl.OgnlRuntime.getProperty(OgnlRuntime.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.ognl.ASTProperty.getValueBody(ASTProperty.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.TextSqlNode$BindingTokenParser.handleToken(TextSqlNode.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.parsing.GenericTokenParser.parse(GenericTokenParser.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.TextSqlNode.apply(TextSqlNode.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.scripting.xmltags.DynamicSqlSource.getBoundSql(DynamicSqlSource.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.mapping.MappedStatement.getBoundSql(MappedStatement.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:) ~[mybatis-3.2..jar:3.2.]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_25]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:) ~[na:1.7.0_25]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:) ~[na:1.7.0_25]
at java.lang.reflect.Method.invoke(Method.java:) ~[na:1.7.0_25]
at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:) ~[mybatis-3.2..jar:3.2.]
at com.github.pagehelper.SqlUtil._processPage(SqlUtil.java:) ~[pagehelper-4.0..jar:na]
at com.github.pagehelper.SqlUtil.processPage(SqlUtil.java:) ~[pagehelper-4.0..jar:na]
at com.github.pagehelper.PageHelper.intercept(PageHelper.java:) ~[pagehelper-4.0..jar:na]
at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:) ~[mybatis-3.2..jar:3.2.]
at com.sun.proxy.$Proxy36.query(Unknown Source) ~[na:na]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_25]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:) ~[na:1.7.0_25]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:) ~[na:1.7.0_25]
at java.lang.reflect.Method.invoke(Method.java:) ~[na:1.7.0_25]
at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:) ~[mybatis-3.2..jar:3.2.]
at tk.mybatis.mapper.mapperhelper.MapperInterceptor.intercept(MapperInterceptor.java:) ~[mapper-3.1..jar:na]
at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:) ~[mybatis-3.2..jar:3.2.]
at com.sun.proxy.$Proxy36.query(Unknown Source) ~[na:na]
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:) ~[mybatis-3.2..jar:3.2.]
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:) ~[mybatis-3.2..jar:3.2.]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.7.0_25]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:) ~[na:1.7.0_25]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:) ~[na:1.7.0_25]
at java.lang.reflect.Method.invoke(Method.java:) ~[na:1.7.0_25]
at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:) ~[mybatis-spring-1.2..jar:1.2.]
... common frames omitted
.::03.888 DEBUG [http-bio--exec-] org.springframework.beans.factory.support.DefaultListableBeanFactory[] - Returning cached instance of singleton bean 'sqlSessionFactory'

这个bug让我好无奈的感觉,所以我只能改了一种方式

select * from t_user where id like CONCAT('%',#{keyword},'%'),只有这样写才可以,弄得我相当郁闷啊。

我这里传入的值完整如下:

  <select id="selecetUserByWord" resultType="java.lang.String" parameterType="java.lang.String">
select id from t_user where
id like CONCAT('%',#{keyword},'%')
</select>

说明:我这里红色部分是指明了是传入单个参数的,如果你传入的是一个对象,然后'%${keyword}%'的话就可以,比如

 <select id="selecetUserByWord" parameterType="com.mouse.snow.User" resultType="java.lang.String">
select id from t_user where
id like '%${keyword}%'
</select>

我也还没找到具体原因,但是在一些群里让群友实验,他们说他们的可以,所以我也好郁闷,因为我个人认为是可以的,不知道是否是配置问题。

三:MyBatis返回键值对形式

我们都知道我们返回的数据都有个resultType对应,有时候我们都是自己写个对象来接收的,但是其实我们有时候又不用的对象的,可以直接把查询的数据转换为键值对的形式就行返回,这里其实可以百度试验下,

Mapper层:
public List<Map<String,Object>> getUserList(); *.xml层:
<select id="selecetUser" resultType="java.util.HashMap">
select id from t_user
</select>

类似这样就可以把查询的数据转换为键值对形式。多条数据那么就是一个list了,这样还是比较方便的。

还有一点没说,就是查询数据的时候本来就是默认把数据转化为键值对的形式如果有对象,才会再去进一步转换的,所以觉得这样直接键值对的形式得到数据的速度会更加迅速的。

这一点是在这里看见的,http://blog.csdn.net/liubo2012/article/details/8261309。

总结

最近其实学到好多知识点,比如阿里云的跨域上传下载等。一些开源的知识等,希望自己每天都能抽出点时间来写点东西,昨天去了一趟香港买了电脑,mac pro,要还几个月的款子啊,努力上班的,boy

最新文章

  1. 【Java并发编程实战】----- AQS(一):简介
  2. renderman、arnold及全局光照
  3. Linux系统目录结构
  4. __slots__ 属性绑定
  5. sqlplus入门基础语句
  6. 自动生成Makefile时,关于Makefile.am编写
  7. javascript之六种数据类型以及特殊注意点
  8. Codeforces Round #278 (Div. 1) B. Strip multiset维护DP
  9. uva 11916 Emoogle Grid
  10. .gitignore模板
  11. TCP通讯处理粘包详解
  12. HDU1865--More is better(统计并查集的秩(元素个数))
  13. Ubuntu下安装Intellij IDEA和PyCharm
  14. Mysql执行计划说明
  15. zabbix 配置本地邮箱报警
  16. centos7源码安装heartbeat可能出现的错误以及解决办法
  17. # C语言假期学习笔记——6
  18. TOSCA自动化测试工具--new Project
  19. sort的用法
  20. Vue keep-alive 组件.

热门文章

  1. “Hello World!“”团队第五周召开的第二次会议
  2. Struts2:Struts2在jsp中使用标签时值的获取
  3. Swift-闭包使用及解决循环引用问题
  4. JAVA程序测试时用到的与内存测试有关的东西
  5. mysql 中文字段排序
  6. MySQL专题 2 数据库优化 Slow Query log
  7. MySQL专题 1 分布式部署数据库同步问题 BinLog
  8. 【数据库】SQL两表之间:根据一个表的字段更新另一个表的字段
  9. Glide加载图片并保存到本地返回file,bitmap
  10. HDU1402:A * B Problem Plus——题解