求解JDBC使用批处理executeBatch()之后commit(),数据库没有变化。 5C

Java的JDBC使用批处理executeBatch()之后commit(),数据库没有变化。

代码

public static boolean newProblem_state(List<User_t> auditorlist, Problems_t problems)throws ClassNotFoundException, SQLException {
        KrakenRecord.debug("正在建立关联"+auditorlist.size());
        Class.forName("com.mysql.jdbc.Driver");
        Connection conn = DriverManager.getConnection(URL, USER, PASSWORD);
        conn.setAutoCommit(false); // 设置手动提交
        String sql = "insert into problemstate_ta (problemstate_problem_id,problemstate_auditor_id,problemstate_state) values("
                + problems.getProblems_id() + ",?,0)";
        PreparedStatement ps = conn.prepareStatement(sql);
        for (User_t user_t : auditorlist) {
            ps.setInt(1, user_t.getUser_id());
            ps.addBatch();// 添加到批次
        }
        int[] i = ps.executeBatch();// 提交批处理
        conn.commit();// 执行
        for (int j : i) {
            System.out.println(j);
        }
        // 关闭资源
        ps.close();
        conn.close();
        return true;
}

以上代码运行后,显示:
正在建立关联4
1
1
1
1
auditorlist的size是4正确,打印的四个1应该是executeBatch()正确执行了,但是数据库没有变化,求解

补充:昨晚发现是插入的数据库没反应,也就是problemstate_ta 这个表,无法插入数据,命令没有写错,在Navicat中窗口模式手动插入数据,数据的自动增长id显示+1,插入数据也没有报错,但是刷新表,数据没了,求解

2个回答

可能是数据库信息没有傻笑,可以试试数据库关闭下再重新打开,或者数据库刷新一下。

没报错,没插入进去,估计你查错库了或表了。对应一下你的配置文件

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
JAVA中使用JDBC做批量处理时,没有报错,但是数据没有插入数据库
@Override public void addAllEmp(List<Employee> employees) { Connection conn = null; PreparedStatement pst = null; try { conn = JDBCUtil.getConnect(); conn.setAutoCommit(false); pst = conn.prepareStatement("insert into jdbc_emp values(jdbc_emp_id.nextval,?,?,?"); int count = 0; for (Employee employee : employees) { pst.setString(1, employee.getName()); pst.setString(2, employee.getPassword()); pst.setDouble(3, employee.getSal()); count++; if (count==100) { //执行批处理 pst.executeBatch(); //清空参数 pst.clearParameters(); count = 0; } } pst.executeBatch(); conn.commit(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { /*if (conn != null) { try { conn.rollback(); } catch (SQLException e1) { e1.printStackTrace(); } }*/ // TODO Auto-generated catch block e.printStackTrace(); }finally{ JDBCUtil.close(conn, pst); }
java 多线程 批量执行JDBC的 executeBatch会产生脏数据嘛
java多线程并发,每个线程中会生成多个sql语句,利用JDBC的executeBatch方法 对每个线程的产生的sql语句进行入库操作,这样会不会导致写入脏数据: 比如:A线程正在写入100条数据,B线程也正在写入100条数据,当执行JDBC的批量执行SQL的时候,会不会把B的数据复制到A的数据 中: JDBC的 方法如下: String sql="insert into xxx(id,ratio,date,status,close)" + "values(?,?,?,?,?)"; PreparedStatement pst=conn.prepareStatement(sql); String code=""; for(Today ts:tslist){ pst.setString(1, ts.getxxx); pst.setDouble(2, ts.getxxx); pst.setInt(3, ts.getxxx); pst.setInt(4, ts.getxxx); pst.setInt(5, ts.getxxx ); pst.addBatch(); } int arr[]=pst.executeBatch(); 这种数据库的批量操作,在多线程下,是不是会产生脏数据,请大牛们解答一下:
JDBC mysql批处理 插入数据似乎遇到了条数限制,请教解决方法
``` protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String sql = "INSERT INTO data VALUES(?)"; PreparedStatement ps = null; try { //设置不允许自动提交数据,connection为类私有变量,在init方法中赋值 connection.setAutoCommit(false); ps = connection.prepareStatement(sql); for (int i = 0; i < 20000; i++) { ps.setObject(1, i); //攒sql ps.addBatch(); //执行batch if (i % 1000 == 0) { ps.executeBatch(); //清空batch ps.clearBatch(); } } //全部执行完后一次提交数据 connection.commit(); } catch (SQLException e) { e.printStackTrace(); } } ``` 只能插入500条不知是不是数据库插入条数限制 mysql URL配置: jdbc:mysql://localhost:3306?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC 我把i的初始值改为10000,再次运行程序,数据库数据没有任何变化
使用addBatch与executeBatch批量处理SQL
我这样写对吗,我感觉好怪异啊,没用过这个东西。 请老哥们,帮我看下改如何修改才能做到同时处理2条SQL 而且那格式化参数,我不知道怎么设置到数据库中,请老哥们帮忙纠正下,或者给个原例子看一下。 那个executeBatch是这样判断是否插入成功吗 谢谢了。 [code="java"] public boolean InsertUpDeOrderData(CheckOutBean bean) { String sql = "insert into tb_order values(?,?,?,?,?,?,?,?,?,?)"; String sq2 = "insert into tb_order_detail values(?,?,?,?,?,?)"; Object [] obj = { bean.getUser_id(),bean.getCh_name(),bean.getAddress(),bean.getPostalcode(), bean.getPhone(),bean.getMobile(),bean.getEmail(),bean.getSendtype(), bean.getPaytype(),bean.getPostscript() }; return this.InsertUpDeOrderData(sql,sq2,obj); } [/code] 这两个方法不在同一类中 [code="java"] public boolean InsertUpDeOrderData(String sql,String sq2 ,Object [] obj){ con = DBUtil.getConnection(); int [] in = null; boolean bool = true; try { con.setAutoCommit(false); stm = con.prepareStatement(sql); stm.addBatch(sql); stm.addBatch(sq2); if(obj != null){ for(int x = 0 ; x<obj.length ; x++){ stm.setObject(x+1, obj[x]); } } in = stm.executeBatch(); for(int x = 0 ; x < in.length; x++){ if(in[x]<=0){ bool = false; } } } catch (SQLException e) { e.printStackTrace(); }finally{ DBUtil.CloseAll(con, stm, rs); } return bool; } [/code]
jdbc批处理的addBatch问题
``` preparedstatement = connection.prepareStatement(sql.toString()); for (int i = 0; i < list.size(); i++) { Map map = list.get(i); Set<Entry> entries = map.entrySet(); for (Entry entry : entries) { preparedstatement.setString(size, entry.getValue().toString()); size++; } preparedstatement.addBatch(); if(++count % DB_BATCHSIZE == 0){ preparedstatement.executeBatch(); } } preparedstatement.executeBatch(); ``` sql语句没有问题, 因为已经执行成功, 但是!!! 只能执行一条数据 list如果只有1条数据则执行成功 , 如果超过1条,报错 错误为 索引中丢失 IN 或 OUT 参数 ::10 搞了一天了没弄明白, 求解
关于 JDBC批处理的问题【求助】
我直接帖代码吧 -- public void batchUpdateXfen(String sql, List<XfenStats> list) { Session session = getHibernateTemplate().getSessionFactory().getCurrentSession(); Connection con= session.connection(); PreparedStatement stmt = null; int count=0; try { con.setAutoCommit(false); stmt = con.prepareStatement(sql); for(int i=0;i<list.size();i++){ count++; stmt.setDouble(1,list.get(i).getSocre()); stmt.setString(2,list.get(i).getId()); stmt.addBatch(); if(count%500==0){ stmt.executeBatch(); con.commit(); stmt.clearBatch(); } } if(count%500!=0){ stmt.executeBatch(); con.commit(); stmt.clearBatch(); } } catch (SQLException e) { e.printStackTrace(); try { con.rollback(); } catch (SQLException e1) { e1.printStackTrace();} }finally{try {if(stmt!=null){ stmt.close();}} } catch (SQLException e) {e.printStackTrace();}}} -- 这里执行不报任何异常,但就是偶尔数据库里不更新数据。 找了很久也没发现问题。。。 是因为事务引起的吗? 配置文件里已经为hibernae 配了事物管理了。 开始session 是Session session = getHibernateTemplate().getSessionFactory().openSession();获取的。所以有时候不执行 后来改了,本地没问题。 但同事那还是有问题,。代码已经同步了。
jdbc preparestatement 批量提交问题
``` public static void addRecord(String tableName,String title,List<Object> contents){ long count = 0; Integer time = 0; Connection conn = getConn(); try { conn.setAutoCommit(false); } catch (SQLException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } PreparedStatement ps = null; StringBuffer sql = new StringBuffer(); StringBuffer sb = new StringBuffer(); try { for (int i = 0; i < contents.size(); i++) { sql.setLength(0); sb.setLength(0); sb.append(((List)contents.get(i)).get(0).toString()); //sql.append("insert into "+tableName+" ("+title+") values ( "+sb.toString().replaceAll("\"","'")+" )"); sql.append("insert into "+tableName+" ("+title+") values ( "+sb.toString()+" )"); ps = conn.prepareStatement(sql.toString()); ps.addBatch(); count++; if(time<=(count/10000)){ if(count%10000==0){ time++; ps.executeBatch(); conn.commit(); //conn.setAutoCommit(true); } } if((time==(contents.size()/10000))&&(count%10000)!=0&&count==contents.size()){ System.out.println("提交数据"); int[] executeBatch = ps.executeBatch(); System.out.println(executeBatch.toString()); conn.commit(); //conn.setAutoCommit(true); } } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ Close(null, ps, null); } ``` 数据不能全部提交而且只有一条不是最后的记录,是中间的记录,为什么??
hibernate 入门 Could not execute JDBC batch update 能在sql数据库中创建一个表,但是不能添加数据
Hibernate: insert into Student (age, name, id) values (?, ?, ?) Exception in thread "main" org.hibernate.exception.GenericJDBCException: Could not execute JDBC batch update at org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:126) at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:114) at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66) at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:275) at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:266) at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:167) at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:321) at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:50) at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1028) at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:366) at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:137) at StudentTest.main(StudentTest.java:27) Caused by: java.sql.BatchUpdateException: java.lang.ArrayIndexOutOfBoundsException: 6 at com.mysql.jdbc.ServerPreparedStatement.executeBatch(ServerPreparedStatement.java:743) at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:70) at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:268)
如何处理JDBC批量插入sql不支持多表的情况下的入库速率不稳定的问题?
是这样的,现在我要从来自Kafka的20多个topic中消费出数据,每个topic对应Clickhouse里面的一个表。 但是Clickhouse的JDBC批量插入只支持预编译SQL,即每个 PrepareStatement对象只能批量插入一个表的数据。如下: ``` Connection connection = getConnection(); PrepareStatement ps = connection.prepareStatement("insert into xxx values (?, ?, ?, ?)"); ps.setObject(1, xxx); ps.setObject(2, xxx); ps.setObject(3, xxx); ps.addBatch(); ps.executeBatch(); ps.clearBatch(); // ...... ``` 所以,我在入库程序把每个表的入库分为不同的线程,分别维护不同的PrepareStatement对象, 入库不同的表。比如现在有20个表,我设定每个表3个线程,那么总共就有60个入库线程。 但是这样子做的话,我无法保证入库的速率稳定,因为有的表数据量大,有的因为业务开启有时较大,而分配的入库线程是固定的。各位盆友有什么解决办法吗? ps:入库程序用的flume,用的官方的KafkaSource,然后写了一个Clickhouse的Sink,每个sink就是对应一个入库clickhouse的线程。Channel用的文件内存通道。当Kafka数据量大时,入库速率远远小于消费速率,可能导致Channel通道满,堆积大量磁盘文件,读写磁盘操作又进一步影响sink取数据,然后越来越慢。。最后Kafka都报一堆问题。 再ps:Clickhouse是6个节点的集群,三个分片,一个副本的配置。我批量插入设置150000条一次批量插入。
jdbc批量插入抛异常,怎么找到有问题的数据
批量插入一批数据,如果这批数据中,有几条是有问题的,executeBatch会出异常,我怎么挑出来,是那几条有问题
Statement executeBatch()批量提交效率好低 求高手答疑
数据大概一共有10W条左右,不固定, 每条sql固定格式都不太一样, 分别是对不同的表做的新增或则修改的操作 所以无法用模板?的形式操作 下面是代码 其中设置的是每1000条数据提交一次 然后这1000条数据却需要大概12S左右, 整个数据跑下来十几分钟 如果是每3000条提交一次,时间也大概是40S左右, 感觉不应该这么慢啊 数据库为Oracle.. 求高手指点一下优化方案 ```java Session session = baseDAO.getSessionFactory().openSession(); Connection conn = session.connection(); Statement stmt = null; try { conn.setAutoCommit(false); // 关闭自动提交 stmt = conn.createStatement(); for(int i=0; i<sqlList.size(); i++){ stmt.addBatch(sqlList.get(i)); //System.out.println(sqlList.get(i)); if (i % 1000 == 0 && i != 0) { long startTime = System.currentTimeMillis(); stmt.executeBatch(); conn.commit(); stmt.clearBatch(); System.out.println("executeBatch 执行使用了 :"+(System.currentTimeMillis() - startTime )/1000 + " 秒"); } } // 执行批处理语句 stmt.executeBatch(); // 执行剩下的不到1000条的数据 conn.commit(); conn.setAutoCommit(true);//在把自动提交打开 } catch (SQLException he) { he.printStackTrace(); try { conn.rollback(); } catch (SQLException e) { e.printStackTrace(); } } finally { if (stmt != null) { try { stmt.close(); } catch (SQLException sqlex) { System.err.println(this.getClass().getName() + ".mymethod - 不能关闭数据库连接: " + sqlex.toString()); } } if (conn != null) { try { conn.close(); } catch (SQLException sqlex) { System.err.println(this.getClass().getName() + ".mymethod - 不能关闭数据库连接: " + sqlex.toString()); } } session.close(); } ```
关于数据库批处理的问题
一般的批处理都是这样的: //使用PreparedStatement进行批处理 PreparedStatement psStatement = connect.prepareStatement("你的SQL语句(?)"); psStatement.setString(1,"Jennie"); psStatement.addBatch(); //根据需要添加多条批处理语句 psStatement.setString(1,"Tom"); psStatement.addBatch(); //获得批处理的结果 int[] uCounts = psStatement.executeBatch(); //和上面一样可以一次性执行 connect.commit(); 现在呢 我想向多个表插入数据也用批处理 并且他们可能交叉在一起不知道能不能实现 那位高人给我一共一个例子看看。 如果我用下方这种方式可不可以提个意见 //使用PreparedStatement进行批处理 PreparedStatement psStatement1 = connect.prepareStatement("你的SQL语句(?)"); psStatement1.setString(1,"Jennie"); psStatement1.addBatch(); //根据需要添加多条批处理语句 PreparedStatement psStatement2 = connect.prepareStatement("你的SQL语句(?)"); psStatement2.setString(1,"Tom"); psStatement2.addBatch(); //获得批处理的结果 int[] uCounts1 = psStatement1.executeBatch(); int[] uCounts2 = psStatement2.executeBatch(); //和上面一样可以一次性执行 connect.commit(); [b]问题补充:[/b] 我只是想用 prepareStatement 这种方法 不知道用这种方法可不可以处理
jdbc批量插入,数据只有一条
我统一10条插入一次,可是最后数据库只有第十条数据,前九条都没有,插入几次都是,怎么办 List<String> backList = new ArrayList<String>(); Connection con = getConnection(); PreparedStatement stat = null; String str= null; int j = 0; for(int i=0;i<list.size();i++){ str = list.get(i); String[] arr = str.split(","); j++; if(arr.length ==10){ try { String name = arr[0]; String pinyin = arr[1]; String age = arr[2]; String sex = arr[3]; String phone = arr[4]; String mobilephone = arr[5]; String address = arr[6]; String birthday = arr[7]; String birthPlace = arr[8]; String company = arr[9]; //根据参数动态拼一个insert语句("+deptno+",'"+dname+"','"+loc+"')" String sql = "insert into user_info "+"values ('"+name+"','"+pinyin+"','"+age+"','"+ sex+"','"+phone+"','"+mobilephone+"','"+address+"','"+birthday+"','"+birthPlace+"','"+company+"')"; stat = con.prepareStatement(sql); System.out.println(sql); stat.addBatch(); System.out.println("sql语句加入批处理中"); } catch (SQLException e2) { // TODO Auto-generated catch block } } if(j == list.size()){ int s [] = stat.executeBatch(); for(int a:s){ System.out.println(a); } } } try { stat.close(); con.close(); } catch (SQLException e1) { e1.printStackTrace(); }
PreparedStatement类的批处理问题
public class Batch { public void batchAdd(){ Connection con=null; PreparedStatement stmt=null; String sql=null; try{ sql = "insert into emp(empno, ename, sal) values(?,?,?)"; con=ConnectionSource.getConnection(); stmt=con.prepareStatement(sql); //关闭自动提交 con.setAutoCommit(false); for(int i=1000;i<105;i++){ stmt.setInt(1, i); stmt.setString(2, "name"+i); stmt.setDouble(3, new Random().nextInt(10000)); // 加入到Batch中 stmt.addBatch(); } //执行批处理 stmt.executeBatch(); //提交 con.commit(); }catch(SQLException e){ System.out.println("数据库访问异常"); throw new RuntimeException(e); }finally{ try{ if(stmt!=null){ stmt.close(); } if(con!=null){ con.close(); } }catch(SQLException e){ System.out.println("释放资源时发生异常"); } } } 写了个 PreparedStatement类的批处理 运行后不会报错 但是数据库中也没有数据!不知道什么原因?难道是因为PreparedStatement的占位符放在for的原因吗?求解!
com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException:
WEB系统报以下的错,是为什么? Caused by: java.sql.BatchUpdateException: Duplicate entry '3592030993-2011-11-23 19:22:45' for key 'PRIMARY' at com.mysql.jdbc.PreparedStatement.executeBatchSerially(PreparedStatement.java:2024) at com.mysql.jdbc.PreparedStatement.executeBatch(PreparedStatement.java:1449) at weblogic.jdbc.wrapper.PreparedStatement.executeBatch(PreparedStatement.java:157) at com.longshine.indigo.dbutils.manager.WrapperStatement.executeBatch(Unknown Source) ... 47 more Caused by: com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException: Duplicate entry '3592030993-2011-11-23 19:22:45' for key 'PRIMARY' at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1036) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3597) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3529) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1990) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2151) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2625) at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2119) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2415) at com.mysql.jdbc.PreparedStatement.executeBatchSerially(PreparedStatement.java:1976) ... 50 more
Hibernate hbm2ddl.auto中参数update不明白
如题,刚学hibernate 不是很明白这个参数到底什么作用,网上查资料说是会改变表结构。 可是我写小例子,却是会报错。 例子就不放上来了,大概是: 实体类和Hibernate Mapping XML文件比数据库中多了一列,然后hibernate.cfg.xml配置文件中hbm2ddl.auto的值为update 但是运行后却会报错,报错代码大概是: Exception in thread "main" org.hibernate.exception.SQLGrammarException: Could not execute JDBC batch update at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:90) at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66) at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:275) at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:266) at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:167) at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:321) at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:50) at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1028) at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:366) at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:137) at test.StudentTest.main(StudentTest.java:35) Caused by: java.sql.BatchUpdateException: Unknown column 'title' in 'field list' at com.mysql.jdbc.PreparedStatement.executeBatchSerially(PreparedStatement.java:1093) at com.mysql.jdbc.PreparedStatement.executeBatch(PreparedStatement.java:851) at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:70) at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:268) ... 8 more 刚刚做了另外一个值的测试,发现create-drop也不像文档上描述的那样:执行完成后会删除。我执行完了之后发现数据库里刚建的表,并没有被删除。
MYSQL批处理插入数据问题
最近在对mysql进行数据插入的时候遇到以下问题,用的是JDBC的PreparedStatement,以BatchUpdate批处理插入的方式进行数据插入,一次数据量为5000条,每5000条数据的间隔基本在10分钟左右,经过一段时间总会报如下错误,百度了下,修改了innodb_lock_wait_time = 500, 错误依旧,不知是为何,求各位高手帮忙,感激不尽!!! java.sql.BatchUpdateException: Lock wait timeout exceeded; try restarting transaction at com.mysql.jdbc.PreparedStatement.executeBatchedInserts(PreparedStatement.java:1836) at com.mysql.jdbc.PreparedStatement.executeBatch(PreparedStatement.java:1456) at com.wisu.xitiancheng.util.DBUtil.insert(DBUtil.java:98) at com.wisu.xitiancheng.servlet.DataHandler.setPresenceData(DataHandler.java:154) at com.wisu.xitiancheng.servlet.SubscriberServlet.sendContentToUI(SubscriberServlet.java:222) at com.wisu.xitiancheng.servlet.SubscriberServlet.handleJsonData(SubscriberServlet.java:204) at com.wisu.xitiancheng.servlet.SubscriberServlet.doPost(SubscriberServlet.java:134) at javax.servlet.http.HttpServlet.service(HttpServlet.java:637) at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849) at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583) at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454) at java.lang.Thread.run(Unknown Source) Caused by: java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1074) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4096) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4028) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2490) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2651) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2734) at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2155) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2458) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2375) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2359) at com.mysql.jdbc.PreparedStatement.executeBatchedInserts(PreparedStatement.java:1792) ... 32 more
关于jdbc事务处理,批量插入数据的问题
部分代码如下: Class.forName(driver).newInstance(); con = DriverManager.getConnection(url,"root","123456"); if (con==null){ System.out.println("NULL"); } String SQL = "Insert into test.test value (null,?,?,?,?,?,?,?,?,?,?,?,?,?);" ; con.setAutoCommit(false); PreparedStatement pst = (PreparedStatement) con.prepareStatement(SQL); while((dbtxtcontent = br.readLine())!=null) { dbtxtcontent = dbtxtcontent.replaceAll("\'",""); String[] val = dbtxtcontent.split(","); boolean flag = false; try { pst.setInt(1, k); k++; pst.setString(2, ""+val[0]); pst.setString(3, ""+val[1]); pst.setString(4, ""+val[2]); pst.setString(5, ""+val[3]); pst.setString(6, ""+val[4]); pst.setString(7, ""+val[5]); pst.setString(8, ""+val[6]); pst.setString(9, ""+val[7]); pst.setString(10, ""+val[8]); pst.setString(11, ""+val[9]); pst.setString(12, ""+val[10]); pst.setString(13, ""+val[11]); pst.addBatch(); } catch (Exception e) { System.err.println("Error CODE:" + e); } line++; } pst.executeBatch(); con.commit(); pst.close(); con.close(); 原程序目的是获取一数据文件内容,并将数据插入数据库。 现在的问题是,数据量较大,全部加入到addBatch,执行时提示内存溢出, 读一条插一条的方法不能在指定的时间内将数据插入数据库, 我想分多次插入,例如每次20000条,数据不是整万的,有零头,尝试了很多次,都没有找到方法 请问大神们该如何修改这段代码?????
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
源码阅读(19):Java中主要的Map结构——HashMap容器(下1)
(接上文《源码阅读(18):Java中主要的Map结构——HashMap容器(中)》) 3.4.4、HashMap添加K-V键值对(红黑树方式) 上文我们介绍了在HashMap中table数组的某个索引位上,基于单向链表添加新的K-V键值对对象(HashMap.Node&lt;K, V&gt;类的实例),但是我们同时知道在某些的场景下,HashMap中table数据的某个索引位上,数据是按照红黑树
c++制作的植物大战僵尸,开源,一代二代结合游戏
    此游戏全部由本人自己制作完成。游戏大部分的素材来源于原版游戏素材,少部分搜集于网络,以及自己制作。 此游戏为同人游戏而且仅供学习交流使用,任何人未经授权,不得对本游戏进行更改、盗用等,否则后果自负。 目前有六种僵尸和六种植物,植物和僵尸的动画都是本人做的。qq:2117610943 开源代码下载 提取码:3vzm 点击下载--&gt; 11月28日 新增四种植物 统一植物画风,全部修
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成喔~) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
深度学习图像算法在内容安全领域的应用
互联网给人们生活带来便利的同时也隐含了大量不良信息,防范互联网平台有害内容传播引起了多方面的高度关注。本次演讲从技术层面分享网易易盾在内容安全领域的算法实践经验,包括深度学习图
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程实用技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法,并会持续更新。
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
"狗屁不通文章生成器"登顶GitHub热榜,分分钟写出万字形式主义大作
前言 GitHub 被誉为全球最大的同性交友网站,……,陪伴我们已经走过 10+ 年时间,它托管了大量的软件代码,同时也承载了程序员无尽的欢乐。 上周给大家分享了一篇10个让你笑的合不拢嘴的Github项目,而且还拿了7万+个Star哦,有兴趣的朋友,可以看看, 印象最深刻的是 “ 呼吸不止,码字不停 ”: 老实交代,你是不是经常准备写个技术博客,打开word后瞬间灵感便秘,码不出字? 有什么
推荐几款比较实用的工具,网站
1.盘百度PanDownload 这个云盘工具是免费的,可以进行资源搜索,提速(偶尔会抽风????) 不要去某站买付费的???? PanDownload下载地址 2.BeJSON 这是一款拥有各种在线工具的网站,推荐它的主要原因是网站简洁,功能齐全,广告相比其他广告好太多了 bejson网站 3.二维码美化 这个网站的二维码美化很好看,网站界面也很...
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
相关热词 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片 c# 图片颜色调整 最快 c#多张图片上传 c#密封类与密封方法
立即提问