Ibatis怎么做批量更新?????

<insert id="updateStatusBatch" parameterClass="hashMap">  
update  
Question  
set  
status = #status#  
<dynamic prepend="where questionId in">  
<isNotNull property="actionIds">  
<iterate property="actionIds" open="(" close=")" conjunction=",">  
#actionIds[]#  
</iterate>  
</isNotNull>  
</dynamic>  
</insert> 

上面的解析成sql就是
update Question  set status = "OK"  where questionId in(1,2,3,4,5...)


到网上找了很多ibatis批量更新的例子,基本上都是这样,我心想难道他们做的项目中只遇到这种把in中的id的status全部更新为同一个值吗,如果每个id对应的status不同呢,怎么做,难道把sql全部放到iterate中吗,这样和for循环没什么区别,郁闷中。。。

小弟不才,刚接触ibatis,想请问ibatis是怎样做批量增改的,

PS:只是单独的ibatis项目,不和spring集成

 

4个回答

有的时候,我们需要一次性插入很多的数据或者一次性更新、删除很多的数据,这是为了提高效率。假如不用批处理 ,相当于是一条一条的插入。而批处理是一次性的修改数据,这样减少了数据库连接的消耗。
至于ibaits 执行
[code="java"]
sqlMapClient.startBatch();

.....
sqlMapClient.executeBatch();

[/code]
,我认为ibatis是对statement的addBatch()方法做了封装。源码没看过 ,但认为原理是这样。
在我做过的项目里,基本是一次性修改万级以上的数据时 会用批处理,我会把数据分多批,一批一批的处理 这样速度快。

ibatis只是对JDBC的封装,真正是否能够一次性批量操作,要看你的数据库类型!
比如:
一次插入多条数据:
INSERT INTO t (t.a, t.b, t.c)
VALUES ('key1','key2','value'), ('key1','key3','value2') ,...

iBatis2通过SqlMapClient提供了一组方法用于批处理实现:
startBatch() 开始批处理
xecuteBatch() 执行批处理

[code="java"]
public void create(List replyList) {

    try {
        // 开始批处理
        sqlMapClient.startBatch();

        for (Reply reply: replyList) {
            // 插入操作
            sqlMapClient.insert("Reply.create", reply);
        }
        // 执行批处理
        sqlMapClient.executeBatch();

    } catch (Exception e) {
        e.printStackTrace();
    }
}

[/code]

[list]
[*]
[/list]

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
求助:ibatis批量更新Mysql数据问题

场景:根据消息号code和状态位status更新所有满足条件的字段值为"T"。怎么批量更新?如果是单个条件的话直接用iterate标签把值放到in('xxx','yyy')循环就行了,where后面跟多个条件的时候mysql怎么处理呢?

ibatis批量修改,,,

ibatis批量修改,传入一个map, String id; List<String> ids = new ArrayList<String>(); List<Object> ls = new ArrayList<Object>(); map.put("id", id); map.put("ids", ids); map.put("ls", ls); sql代码: <update id="editLimit" parameterClass="java.util.HashMap"> update dic_limit_value set <iterate property="ls" open="case" close="end" > LIMIT_VALUE = #ls[].limitValue#,ERROR_LIMIT = #ls[].errorLimit#,EX_LIMIT = #ls[].exLimit# </iterate> where BTS_ID = #stid# <isNotNull property="ls"> and LIMIT_ID in <iterate property="ls" conjunction="," open="(" close=")"> #ls[].limitIDs# </iterate> </isNotNull> </update> 这样的写法是错的,请问应该怎么写

ibatis 批量插入!!!!?????

获得map ``` String insertCompId = "a,b,c"; String ttId = "a,b,c"; String ticketCode = "a"; String[] insertCompIdaa = insertCompId.split(","); String[] ttidaa = ttId.split(","); try{ sqlMapClient.startTransaction(); Map map = new HashMap(); List<TestInsert> tilist = new ArrayList<TestInsert>(); for (int i = 0; i < ttidaa.length; i++) { for (int j = 0; j < insertCompIdaa.length; j++) { TestInsert ti =new TestInsert(); ti.setTicketTypeId(ttidaa[i]); ti.setTicketCodeType(ticketCode); ti.setComponentId(insertCompIdaa[j]); tilist.add(ti); } } map.put("tilist", tilist); ......... ``` 将上面得到的map,传入 ``` <insert id="testInsertTicketCodeRelation" parameterClass="java.util.Map" > insert all <iterate property="tilist" conjunction=","> into TICKET_TYPE_TICKET_CODE ( TICKET_TYPE_TICKET_CODE_ID, TICKET_TYPE_ID, TICKET_CODE_TYPE, COMPONENT_ID ) values ( TICKET_TYPE_AND_CODE_ID_SEQ.nextVal, #tilist[].ticketTypeId#, #tilist[].ticketCodeType#, #tilist[].componentId# ) </iterate> select * from dual </insert> ``` 出错(当ttId和insertCompId为单字符,例如ttId=“a”insertCompId=“b”,这样的,是不会报错,只有为上面的有逗号的字符串时,才会出现这个错误) ``` ERROR [http-bio-8080-exec-4] LoggerFactory.invoke(38) | class com.hkt.engineering.oneoss.ticketing.dao.tickettype.impl.TicketTypeTicketCodeDAO.testInsertTicketCodeRelation() invoke error ERROR [http-bio-8080-exec-4] LoggerFactory.invoke(39) | error info: com.ibatis.common.jdbc.exception.NestedSQLException: --- The error occurred while applying a parameter map. --- Check the EFT_TICKET_TYPE_TICKET_CODE.testInsertTicketCodeRelation-InlineParameterMap. --- Check the statement (update failed). --- Cause: java.sql.SQLException: ORA-00928: 缺失 SELECT 关键字 ``` 请问,问题出在哪里了?

IBATIS像mysql中批量新增问题

这是ibatis sqlmap中的 sql <insert id="updateCredit" parameterClass="com.spci.po.MemberMerchant"> <![CDATA[ insert INTO t_member_credit (ID,MEMBER_ID,TRADE_ID,BALANCE) VALUES (#id#,#memberId#,#tradeId#,#balance#) ON DUPLICATE KEY UPDATE BALANCE=#balance# ]]> </insert> 这是DAO种的执行代码 public void bathInsertObject(final String sql, final List list) { try { //this.getSqlMapClient().startTransaction(); this.getSqlMapClient().startBatch(); for (int i = 0; i < list.size(); i++) { this.insertObject(sql, list.get(i)); } //this.getSqlMapClient().commitTransaction(); //this.getSqlMapClient().endTransaction(); this.getSqlMapClient().executeBatch(); } catch (SQLException e) { logger.error("批量添加错误"+sql,e); } } 目的:为了实现mysql中存在数据就批量新增 不存在就批量更新,上面的sql已经在数据库中执行sql验证可用 结果:通过Ibatis调用后 只新增了一条数据,而不是多条 PS:在执行普通的批量新增时 上面的代码是可用的 请问哪里出错了?如何解决

ibatis动态更新字段

[code="java"] public class User { private String id; private String username; private String password; //省略get/set } [/code] XML配置文件 [code="java"] <update id="updateUser" parameterClass="user"> update user set username=#username#,password=#password# where id=#id# </update> [/code] 我想做的是如果User里面的password是null,那么update语句中password=#password#就省去。在百度,Google实在找不到这方面的资料了。麻烦大虾们了

Java Oracle Ibatis 批量 Insert 出错(SQL执行出错???)!!!!

Java,map部分 ``` String insertCompId = "123,234"; String ttId = "123,234"; String ticketCode = "abc"; String[] insertCompIdaa = insertCompId.split(","); String[] ttidaa = ttId.split(","); Map map = new HashMap(); List<String> ttIdList = new ArrayList<String>(); List<String> insertCompIdList = new ArrayList<String>(); for (int i = 0; i < ttidaa.length; i++) { for (int j = 0; j < insertCompIdaa.length; j++) { ttIdList.add(ttidaa[i]); insertCompIdList.add(insertCompIdaa[j]); } } map.put("tickettypeid", ttIdList); map.put("ticketcodetype", ticketCode); map.put("insertcompid", insertCompIdList); ``` 在上面拿到map后,传到执行SQL的部分 SQL部分 ``` <insert id="testInsertTicketCodeRelation" parameterClass="java.util.Map" > INSERT ALL <iterate> INTO TICKET_TYPE_TICKET_CODE ( TICKET_TYPE_TICKET_CODE_ID, TICKET_TYPE_ID, TICKET_CODE_TYPE, COMPONENT_ID ) VALUES ( TICKET_TYPE_AND_CODE_ID_SEQ.nextVal, #tickettypeid[]#, #ticketcodetype#, #insertcompid[]# ) </iterate> SELECT 1 FROM DUAL </insert> ``` 下面是报错 ``` java.sql.SQLException: Insert statements cannot be executed as a query. at com.ibatis.sqlmap.engine.mapping.statement.InsertStatement.executeQueryForObject(InsertStatement.java:35) at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForObject(SqlMapExecutorDelegate.java:518) at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForObject(SqlMapExecutorDelegate.java:493) at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryForObject(SqlMapSessionImpl.java:106) at com.ibatis.sqlmap.engine.impl.SqlMapClientImpl.queryForObject(SqlMapClientImpl.java:82) at com.hkt.engineering.oneoss.ticketing.dao.tickettype.impl.TicketTypeTicketCodeDAO.testInsertTicketCodeRelation(TicketTypeTicketCodeDAO.java:280) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ........(剩下部分省略) ``` 错误有点长,请各位帮忙看看,这个错误怎么产生的,要怎么解决,谢谢!!!

ibatis动态查找出错

<select id="getByTypeIDs" resultMap="result"> SELECT DET_NAME FROM TYPE_DEATAIL <dynamic prepend="where"> <iterate property="detTypeId" open="(" close=")" conjunction="or"> DET_TYPE_ID=#detTypeId[]# </iterate> </dynamic> </select> public List getByTypeIDs(int detTypeId[])throws SQLException{ return sqlMapper.queryForList("getByTypeIDs",detTypeId); } 2008-08-08 14:55:40,937 DEBUG [java.sql.Connection] - {conn-100000} Connection 2008-08-08 14:55:40,937 DEBUG [com.ibatis.common.jdbc.SimpleDataSource] - Returned connection 1623405 to pool. at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryWithCallback(GeneralStatement.java:156) ... 7 more Caused by: java.lang.StringIndexOutOfBoundsException: String index out of range: -1 at java.lang.String.substring(Unknown Source) at com.ibatis.common.beans.BaseProbe.getIndexedProperty(BaseProbe.java:50) ... 15 more

这Ibatis更新语句,该怎么写?

比方我的java bean 名字叫user 定义三个属性 ID name pwd add 对应数据库的表为 table 列名 ID NAME PWD ADD 当我更新时 我只要根据ID更新 pwd 和add 正常在sql中 写成 update table set pwd=? set add=? where ID=? 我在Ibatis中这样写 <update id="updateUser" parameterClass="user"> update table set ID=#ID#, NAME=#name#,PWD=#pwd#,ADD=#add# where ID=#ID# </update> 我只能先在数据库中根据ID查出user 然后根据前台输入获取pwd 和add 并且set到user中,ID和name的值仍是数据库中的值没变,最后通过 这个ibatis语句 把user 给update,我刚学对ibatis机制还是不太了解,不知道这样对不对。?? 其实我想问 能不能只设置需要更新的 2个字段,它能不能自动找到java bean中的属性 进行匹配。就像下面: <update id="updateUser" parameterClass="user"> update table set PWD=#pwd#,ADD=#add# where ID=#ID# </update> 这样能不能更新成功呢,谢谢指点~~~!!!

ibatis 动态sql中<isNotEmpty>更新字段为空问题

有个这样的场景,有一条记录每个字段都有值,现在在表单中使某个字段的值为空, 然后保存在后台执行更新,后台ibatis中动态sql是<isNotEmpty>标签导致更新不了这个字段为空。 <isNotEmpty>是判断null 和 “”的。换成<isNotNull>就可以了。 因为项目中很多地方更新使用了<isNotEmpty>标签,有没有什么办法可重新ibatis的方法,实现自己的逻辑呢。或者其他方法可提供呢。 请大神指教。

sql 批量更新 一个(还有多个选项的)字段

有2张表 一个学生表,一个状态表 学生表里面有个字段是学生奖项(1,2,3) 对应的奖项名称是状态表里面的内容。 !!! 主要内容: 是通过学生的id(批量)修改奖项(awards)这个字段,每个青年的奖项可能不同(如:A学生有:2,3。B学生有:3,4)。奖项也是含有多个值的(如1,2,3,4,5。。) 现在要去掉其中一个奖项,或者增加一个奖项。 sql语句要如何写?用ibatis如何操作。

ibatis如果传入list参数 数据库查不到结果集时报下标越界错误

用ibatis传入的一个list集合 需要用到其中的主键ID, 但是其中只有某些ID可以查到结果集,这样的话ibatis会报下标越界错误 有什么解决方法吗

ibatis 用自动生成的dao层,想要找到list。怎么写

public List<GameSDK> getGameSDKList(){ GameSDKExample example = new GameSDKExample(); dao.selectByExample(example); return null; 求大神给写一下该怎么获得列表了??

IBatis插入一条记录后,如何返回记录ID值

下面是IBatis将用户插入数据库的例子: 1. MySQL定义 CREATE TABLE `user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `name` char(80) NOT NULL, `age` int(11) DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `id` (`id`) ) 2. User定义 public class User { private Long id; private String name; private int age; ... } 3. 定义UserMapper [code="java"]<mapper namespace="org.hyn.maper.UserMapper"> <insert id="insert" parameterType="org.hyn.bean.User"> insert into author(name,age) values(#{name},#{age}) </insert> </mapper>[/code] 4. 增加一个用户的程序片段 [code] ApplicationContext aContext = new FileSystemXmlApplicationContext("WebRoot/WEB-INF/applicationContext.xml"); UserMapper userMapper = aContext.getBean(UserMapper.class); User user = new User(); user.setName("张三"); user.setAge(18); userMapper.insert(user);[/code] 问题:如何才能得到加入记录"张三"的ID值? 能在插入时直接回填ID吗?

ibatis如何维护多对多关系?

<p>最近使用ibatis遇到一些困惑,请教大家一下。<br>举个例子:现在有学生,课程,选课关系三张表。<br>在实现学生选课功能中,用ibatis维护选课关系这张表比较好?<br>有两个想法:1、单独建ralation Entity维护选课关系表<br>                  2、放到 sutdent 和 course 中维护<br>个人倾向第一种,大家一般是怎么做的,详细说一下。</p>

jason字符串 用ibatis 插入到mysql 数据库 同时插入多条数据

问题是这样的 {"openId":"xx","question":[{"questionId":"xx","selectName":"xx"},{"questionId":"xx","selectName":"xx"},{"questionId":"xx","selectName":"xx"},{"questionId":"xx","selectName":"xx"}]} 要将这个jason字符串 插入数据库里的这个字符串里有一个 openId 表示是一个人填的答题,然后有4道题 题目 和对应的答案 用的是ibatis 插入mySql 数据库,sql该怎么写? (插入数据库应该有4条数据,openId都一样的,) 或者应该怎么处理这个步骤?![图片说明](https://img-ask.csdn.net/upload/201607/07/1467861159_456044.jpg)

如何只显示ibatis的日志

项目里使用了struts2、spring、ibatis,我想查看ibatis的sql语句,如下配置可以显示: ### set log levels - ALL,DEBUG,INFO,WARN,ERROR,FATAL,OFF ### log4j.rootLogger=DEBUG,CONSOLE_DEBUG log4j.addivity.org.apache=true # SqlMap logging configuration... log4j.logger.com.ibatis=DEBUG log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG log4j.logger.java.sql.Connection=DEBUG log4j.logger.java.sql.Statement=DEBUG log4j.logger.java.sql.PreparedStatement=DEBUG log4j.logger.java.sql.ResultSet=DEBUG # ConsoleAppender log4j.appender.CONSOLE_DEBUG=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE_DEBUG.Threshold=DEBUG log4j.appender.CONSOLE_DEBUG.Target=System.out log4j.appender.CONSOLE_DEBUG.layout=org.apache.log4j.PatternLayout log4j.appender.CONSOLE_DEBUG.layout.ConversionPattern= [%-5p][%F]%n%m%n 但是同时会输出struts、spring的日志,很多啊,我只想看ibatis的日志,请问怎么样把struts和spring的日志过滤掉呢?

IBATIS中sql语句执行的判断

页面中会传过来MAX_VALUE和MIN_VALUE两个值 当页面没有接收到这个值时,执行一个A这个SQL语句 当页面中接收到MAX值时,执行B这个SQL语句 当页面中接收到MIN值时,执行C这个SQL语句 当MAX和MIN两个值都接收到,执行D这个SQL语句,这个IBATIS的.xml文件要怎么写

ibatis转换的一个问题

2016-10-15 17:18:39,162 ERROR (com.test.framework.progress.utils.ProgressUtils:126) - poolTaskExecutor 线程池:SqlMapClient operation; uncategorized SQLException for SQL []; SQL state [null]; error code [0]; --- The error occurred in com/test/framework/dao/ibatis2/ibatis.xml. --- The error occurred while applying a result map. --- Check the com.test.lol.code.sql.selectCodeInfoByCond-AutoResultMap. --- The error happened while setting a property on the result object. --- Cause: net.sf.cglib.beans.BulkBeanException: java.lang.String cannot be cast to java.lang.Long; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException: --- The error occurred in com/test/framework/dao/ibatis2/ibatis.xml. --- The error occurred while applying a result map. --- Check the com.test.lol.code.sql.selectCodeInfoByCond-AutoResultMap. --- The error happened while setting a property on the result object. --- Cause: net.sf.cglib.beans.BulkBeanException: java.lang.String cannot be cast to java.lang.Long org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation; uncategorized SQLException for SQL []; SQL state [null]; error code [0]; --- The error occurred in com/test/framework/dao/ibatis2/ibatis.xml. --- The error occurred while applying a result map. --- Check the com.test.lol.code.sql.selectCodeInfoByCond-AutoResultMap. --- The error happened while setting a property on the result object. --- Cause: net.sf.cglib.beans.BulkBeanException: java.lang.String cannot be cast to java.lang.Long; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException: --- The error occurred in com/test/framework/dao/ibatis2/ibatis.xml. --- The error occurred while applying a result map. --- Check the com.test.lol.code.sql.selectCodeInfoByCond-AutoResultMap. --- The error happened while setting a property on the result object. --- Cause: net.sf.cglib.beans.BulkBeanException: java.lang.String cannot be cast to java.lang.Long at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:83) at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80) at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80) at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:203) at org.springframework.orm.ibatis.SqlMapClientTemplate.executeWithListResult(SqlMapClientTemplate.java:243) at com.test.framework.dao.ibatis2.Ibatis2SqlMapClientTemplate.query4VCommList(Ibatis2SqlMapClientTemplate.java:129) at com.test.framework.dao.ibatis2.Ibatis2SqlMapClientTemplate.queryForVCommList(Ibatis2SqlMapClientTemplate.java:225) at com.test.lol.code.service.CodeServiceImpl.selectCodeInfoByCond(CodeServiceImpl.java:2508) at com.test.lol.code.service.CodeServiceImpl$$FastClassByCGLIB$$740dee32.invoke(<generated>) at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:149) at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:689) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150) at org.springframework.aop.aspectj.AspectJAfterAdvice.invoke(AspectJAfterAdvice.java:42) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:55) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:90) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:622) at com.test.lol.code.service.CodeServiceImpl$$EnhancerByCGLIB$$ab958bb2.selectCodeInfoByCond(<generated>) at com.test.lol.code.action.CodeAction.selectCodeInfoByCond(CodeAction.java:243) at com.test.lol.code.action.ExportallAction.category(ExportallAction.java:306) at com.test.lol.code.action.ExportallAction.exportyAll(ExportallAction.java:274) at com.test.lol.code.action.ExportallAction$1.execute(ExportallAction.java:221) at com.test.framework.progress.utils.ProgressUtils$2.run(ProgressUtils.java:124) at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) at java.lang.Thread.run(Thread.java:662) Caused by: com.ibatis.common.jdbc.exception.NestedSQLException: --- The error occurred in com/test/framework/dao/ibatis2/ibatis.xml. --- The error occurred while applying a result map. --- Check the com.test.lol.code.sql.selectCodeInfoByCond-AutoResultMap. --- The error happened while setting a property on the result object. --- Cause: net.sf.cglib.beans.BulkBeanException: java.lang.String cannot be cast to java.lang.Long at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.executeQueryWithCallback(MappedStatement.java:204) at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.executeQueryForList(MappedStatement.java:139) at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForList(SqlMapExecutorDelegate.java:567) at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForList(SqlMapExecutorDelegate.java:541) at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryForList(SqlMapSessionImpl.java:118) at com.test.framework.dao.ibatis2.Ibatis2SqlMapClientTemplate$1.doInSqlMapClient(Ibatis2SqlMapClientTemplate.java:131) at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:200) ... 26 more Caused by: net.sf.cglib.beans.BulkBeanException: java.lang.String cannot be cast to java.lang.Long at com.test.lol.code.valueobject.CodeInfo$$BulkBeanByCGLIB$$80c55f8f.setPropertyValues(<generated>) at com.ibatis.sqlmap.engine.accessplan.EnhancedPropertyAccessPlan.setProperties(EnhancedPropertyAccessPlan.java:33) at com.ibatis.sqlmap.engine.exchange.JavaBeanDataExchange.setData(JavaBeanDataExchange.java:112) at com.ibatis.sqlmap.engine.mapping.result.ResultMap.setResultObjectValues(ResultMap.java:371) at com.ibatis.sqlmap.engine.mapping.result.AutoResultMap.setResultObjectValues(AutoResultMap.java:54) at com.ibatis.sqlmap.engine.mapping.statement.RowHandlerCallback.handleResultObject(RowHandlerCallback.java:64) at com.ibatis.sqlmap.engine.execution.SqlExecutor.handleResults(SqlExecutor.java:385) at com.ibatis.sqlmap.engine.execution.SqlExecutor.handleMultipleResults(SqlExecutor.java:300) at com.ibatis.sqlmap.engine.execution.SqlExecutor.executeQuery(SqlExecutor.java:189) at com.test.framework.dao.ibatis2.LimitSqlExecutor.executeQuery(LimitSqlExecutor.java:82) at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.sqlExecuteQuery(MappedStatement.java:221) at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.executeQueryWithCallback(MappedStatement.java:189) ... 32 more Caused by: java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Long ... 44 more

Ibatis缓存问题?

hibernate查询的时候,会先到缓存里查询,如果没有就去数据库理查,然后返回记录给程序,并填充缓存,第二次查询的时候就不用在去和数据库进行通讯了。直接从缓存里去。。 我想知道IBatis是不是也是这样的?

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

Python代码实现飞机大战

文章目录经典飞机大战一.游戏设定二.我方飞机三.敌方飞机四.发射子弹五.发放补给包六.主模块 经典飞机大战 源代码以及素材资料(图片,音频)可从下面的github中下载: 飞机大战源代码以及素材资料github项目地址链接 ————————————————————————————————————————————————————————— 不知道大家有没有打过飞机,喜不喜欢打飞机。当我第一次接触这个东西的时候,我的内心是被震撼到的。第一次接触打飞机的时候作者本人是身心愉悦的,因为周边的朋友都在打飞机, 每

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

如何在虚拟机VM上使用串口

在系统内核开发中,经常会用到串口调试,利用VMware的Virtual Machine更是为调试系统内核如虎添翼。那么怎么搭建串口调试环境呢?因为最近工作涉及到这方面,利用强大的google搜索和自己

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

北京师范大学信息科学与技术学院笔试10复试真题

北京师范大学信息科学与技术学院笔试,可以更好的让你了解北师大该学院的复试内容,获得更好的成绩。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

Tomcat服务器下载、安装、配置环境变量教程(超详细)

未经我的允许,请不要转载我的文章,在此郑重声明!!! 请先配置安装好Java的环境,若没有安装,请参照我博客上的步骤进行安装! 安装Java环境教程https://blog.csdn.net/qq_40881680/article/details/83585542 Tomcat部署Web项目(一)·内嵌https://blog.csdn.net/qq_40881680/article/d...

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

图书管理系统(Java + Mysql)我的第一个完全自己做的实训项目

图书管理系统 Java + MySQL 完整实训代码,MVC三层架构组织,包含所有用到的图片资源以及数据库文件,大三上学期实训,注释很详细,按照阿里巴巴Java编程规范编写

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

[已解决]踩过的坑之mysql连接报“Communications link failure”错误

目录 前言 第一种方法: 第二种方法 第三种方法(适用于项目和数据库在同一台服务器) 第四种方法 第五种方法(项目和数据库不在同一台服务器) 总结 前言 先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈), 在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好...

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

2021考研数学张宇基础30讲.pdf

张宇:博士,全国著名考研数学辅导专家,教育部“国家精品课程建设骨干教师”,全国畅销书《张宇高等数学18讲》《张宇线性代数9讲》《张宇概率论与数理统计9讲》《张宇考研数学题源探析经典1000题》《张宇考

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

期末考试评分标准的数学模型

大学期末考试与高中的考试存在很大的不同之处,大学的期末考试成绩是主要分为两个部分:平时成绩和期末考试成绩。平时成绩和期末考试成绩总分一般为一百分,然而平时成绩与期末考试成绩所占的比例不同会导致出现不同

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

c语言项目开发实例

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

相关热词 c# dbml文件 修改 c#遍历tree c# 能够控制单片机 c#对象写入数据库 c# 添加activex c#2005 json c# 数据库在云端 c# 字符串移位加密 c#禁用滚轮 c#实体类list去重复
立即提问