oracle clob如何写入6W+字符

我用的数据库是oracle。。想往clob里面写入一条6W+的字符串,老师报错,说字符串太长

2个回答

CLOB最大4g,存入6万字符没问题,关键看你客户端程序本身调用sql的限制。

理论上来说6W+肯定没问题,

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
oracle clob如何写入6W+字符
我用的数据库是oracle。。想往clob里面写入一条6W+的字符串,老师报错,说字符串太长
在Oracle中,一个很短的字符存在Clob中被截断
在Oracle中,一个很短的字符存在Clob中被截断 以前别人的的一个存储过程,用Clob字段拼接的SQL,今天突然报错,我跟踪了下,发现存在Clob中的字符被截断,其中有个字符串很短,能在Varchar2中存储,但是也被截断了,这是什么问题? 如果改写SQL语句的话比较麻烦,所以还是希望继续用Clob字段,有没有人碰到这个问题?
oracle中clob类型超长字符串如何截取与处理
各位大神,现在有一个表中有一个字段的类型是clob类型,里面存储了25w字符长度的数字,这些数字都是以逗号分割开的,我想把这个25w长度的字符串全部以逗号为分隔符,把里面的所有的数据都截取出来,再输入到数组中,不知道这个问题该怎么解决啊?求大神,谢谢。 另,我知道可以使用dbms-lob.substr截取,和instr()识别逗号的位置,数组我也已经自定义好了,可是由于varchar2的长度限制,每次只能截取32767长度的字符串,而且instr函数也是处理长度限制,我不知道能不能直接加大限制,直接进行截取,还是必须得分段截取,那该怎么分段呢? 实在不知道该怎么处理这个25w长度的大数据字符串了 <( ̄3 ̄)>
oracle 自定义聚合函数处理clob时间过长的问题如何解决
大神们,现有一问题,我自定义了一个类型和函数,用来聚合处理一个表中的某个字段的所有值,如下是类型![图片说明](https://img-ask.csdn.net/upload/201709/20/1505871910_379838.png)![图片说明](https://img-ask.csdn.net/upload/201709/20/1505871930_361029.png) 然后我又写了个存储过程用来执行这个函数,存储过程如下:![图片说明](https://img-ask.csdn.net/upload/201709/20/1505872026_568998.png)其中我把TEST_TABLE_ORDER表中的position字段和strain字段的所有值都使用自定义的类型函数聚合存到了两个clob里面,进而存入了Test_Table_Info表中,这个过程和原理都没什么问题,存储过程可以正常执行,但是执行一次需要2分30秒的时间才能完成一次聚合,聚合的原数据存储形式为如下: ![图片说明](https://img-ask.csdn.net/upload/201709/20/1505873170_651951.png) 聚合之后的数据存储形式为如下:![图片说明](https://img-ask.csdn.net/upload/201709/20/1505873261_908765.png)其中position_clob和strain_clob字段都是clob数据类型,存储聚合之后的数据 目前我经过网上查资料,暂时这么解决字符串聚合问题的,但是用时太长了,无法满足项目要求,最好是把聚合存储和截取读取的时间控制在60秒或60秒之内,这样就可以了,所以再次想请教各位大神们这个该怎么优化啊?要是我这个无法优化的话,该换个啥方法呀?
ORA-01704:字符串文字太长 的java解决办法?
用java写了个工具用来导数据,从mysql导入oracle,可oracle关于clob的字段有4k的限制,clob类型的字段太大的数据插入报exception,不知如何解决(没有用hibernate,纯jdbc程序,设置SetBigStringTryClob的方法不行) [b]问题补充:[/b] 解决了,不能直接拼sql插入,用preparedStatement,创建一个Clob对象,然后把从mysql取得的长字符串转成这个对象,再以Clob的方式插入oracle就可以了。
写入blob问题
问题:下面“再将Blob/Clob字段更新到数据库 ”那段代码部分是必须的吗?我在网上搜到的代码似乎都没那段!没那段数据似乎插入不了。 PreparedStatement ps = conn.prepareStatement( " insert into PICTURE(image,resume) values(?,?) " ); // 通过oralce.sql.BLOB/CLOB.empty_lob()构造空Blob/Clob对象 ps.setBlob( 1 ,oracle.sql.BLOB.empty_lob()); ps.setClob( 2 ,oracle.sql.CLOB.empty_lob()); ps.excuteUpdate(); ps.close(); // 再次对读出Blob/Clob句柄 ps = conn.prepareStatement( " select image,resume from PICTURE where id=? for update " ); ps.setInt( 1 , 100 ); ResultSet rs = ps.executeQuery(); rs.next(); oracle.sql.BLOB imgBlob = (oracle.sql.BLOB)rs.getBlob( 1 ); oracle.sql.CLOB resClob = (oracle.sql.CLOB)rs.getClob( 2 ); // 将二进制数据写入Blob FileInputStream inStream = new FileInputStream( " c://image.jpg " ); OutputStream outStream = imgBlob.getBinaryOutputStream(); byte [] buf = new byte [ 10240 ]; int len; while (len = inStream.read(buf) > 0 ) { outStream.write(buf, 0 ,len); } inStream.close(); outStream.cloese(); // 将字符串写入Clob resClob.putString( 1 , " this is a clob " ); [color=red]// 再将Blob/Clob字段更新到数据库 [b]ps = conn.prepareStatement( " update PICTURE set image=? and resume=? where id=? " ); ps.setBlob( 1 ,imgBlob); ps.setClob( 2 ,resClob); ps.setInt( 3 , 100 ); ps.executeUpdate(); ps.close();[/b][/color]
spring jdbctemplate操作clob
jdk1.6+tomcat6 oracle11g驱动ojdbc6 找了很久了,驱动包换了N个了,就是不行 插入2000个以下字符没问题,超出就会报错 java里的方法: [code="java"] String sql = "insert into test_clob(detail) values(?)"; getTemplate().execute(sql, new AbstractLobCreatingPreparedStatementCallback(lobHandler) { @Override protected void setValues(PreparedStatement pstm, LobCreator lobCreator) throws SQLException, DataAccessException { lobCreator.setClobAsString(pstm, 1, text); } }); [/code] 配置文件: [code="java"] <bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" lazy-init="true"> </bean> [/code] 错误信息: [code="java"] org.springframework.jdbc.support.lob.DefaultLobHandler&quot;</span></i></span></div> org.springframework.jdbc.UncategorizedSQLException: (executing PreparedStatementCallback [org.springframework.jdbc.core.JdbcTemplate$SimplePreparedStatementCreator@34e6e3]): encountered SQLException [数据大小超出此类型的最大值: 71472]; nested exception is java.sql.SQLException: 数据大小超出此类型的最大值: 71472 java.sql.SQLException: 数据大小超出此类型的最大值: 71472 at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134) at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179) at oracle.jdbc.ttc7.TTCItem.setArrayData(TTCItem.java:147) at oracle.jdbc.dbaccess.DBDataSetImpl.setBytesBindItem(DBDataSetImpl.java:2461) at oracle.jdbc.driver.OraclePreparedStatement.setItem(OraclePreparedStatement.java:1155) at oracle.jdbc.driver.OraclePreparedStatement.setString(OraclePreparedStatement.java:1572) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at org.logicalcobwebs.proxool.ProxyStatement.invoke(ProxyStatement.java:100) at org.logicalcobwebs.proxool.ProxyStatement.intercept(ProxyStatement.java:57) at oracle.jdbc.internal.OracleStatement$$EnhancerByProxool$$16a7118c.setString(<generated>) at org.springframework.jdbc.support.lob.DefaultLobHandler$DefaultLobCreator.setClobAsString(DefaultLobHandler.java:106) at com.blackstar.project.service.ProjectService$1.setValues(ProjectService.java:71) at org.springframework.jdbc.core.support.AbstractLobCreatingPreparedStatementCallback.doInPreparedStatement(AbstractLobCreatingPreparedStatementCallback.java:71) at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:450) at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:469) at com.blackstar.project.service.ProjectService.addProject(ProjectService.java:65) at com.blackstar.project.action.ProjectAction.executeTask(ProjectAction.java:77) at com.blackstar.system.ComTemplateAction.execute(ComTemplateAction.java:46) at org.springframework.web.struts.DelegatingActionProxy.execute(DelegatingActionProxy.java:105) at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:421) at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:226) at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1164) at com.blackstar.system.MyActionServlet.process(MyActionServlet.java:42) at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:415) 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.extremecomponents.table.filter.AbstractExportFilter.doFilter(AbstractExportFilter.java:49) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at com.blackstar.system.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:22) 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:127) 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:298) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859) at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588) at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) at java.lang.Thread.run(Thread.java:619) [/code]
ORACLE 解决使用“wmsys.wm_concat() ”连接超限再次遇到处理时间过长的问题
各位大佬,现有数据库的两个表,其中我使用wmsys.wm_concat()函数把 **表一** 中的一个字段所有数据聚合起来之后,发现已经过了限制,我算了一下聚合起来之后的字符串的数据长度大概在25w左右,然后我网上查了半天,使用 “ 修改自定义类型中内部变量的类型”的办法解决了这个超限的问题,写了一个存储过程,使得聚合起来的这条数据成功插入到了 **表二** 的clob字段中。 但是之后我发现了一个更大的问题,由于要聚合的字段下的数据太多,而我的存储过程中写的聚合的是两个字段的数据和存储,所以执行一次这个存储过程需要2分40秒的时间,这个时间系统是无法忍受的,无法满足需求的,我不知道该怎么解决这个问题了,要是实在没办法我就换个方法不用这个自定义类型的方法了,求助各位大佬该怎么优化一下呢?
crystal report 8.5 data missing 问题
crystal report 8.5 data missing 问题 用oracle 8.1.7,有一个clob 类型field,有1200多个字符,可report 只能显示1000个字符, 有遇到这个问题的吗?怎么解决
perl 如何存储超过4000的字段进入oracle
if ($row->{interfacetype} eq 'DATA') { my $sth = $dbh->prepare(qq{ INSERT INTO DEV_AUDIT_RECORD ( RECORD_ID, CREATE_TIME, MEMBER_ID, AUDIT_STATE, AUDIT_TYPE, AUDIT_CONTENT, AUDIT_CONTENT_ORIGIN, PUBLISHER_ID, PUBLISHER_NICKNAME, PUBLISHER_IP, PUBLISH_TIME, SECTION, MESSAGE_ID, MESSAGE_ORIGIN, MESSAGE_CLASS, MESSAGE_REPRINT, CONTENT_ID, CONTEXT_ID, CONTEXT, ORDER_TYPE, USER_TYPE) VALUES ( DEV_AUDIT_RECORD_ID_SEQUENCE.nextval, :create_time, :member_id, :audit_state, :audit_type,?, :audit_content_origin, :publisher_id, :publisher_nickname, :publisher_ip, :publish_time, :section, :message_id, :message_origin, :message_class, :message_reprint, :content_id, :context_id, :context, :order_type, :user_type) RETURNING RECORD_ID INTO :record_id }); if (!$sth or $dbh->err()) { $logger->info($dbh->errstr()); } else{ use utf8; my ($commp, $dept, $product, $sub) = get_section($row->{section}); my $message_origin = encode('gbk', decode('utf-8', $product)); my $message_class = encode('gbk', decode('utf-8', $sub)); my $content_nohtml = $msg->{CONTENT}; $content_nohtml =~ s/<\/?[^>]*>//ig; $sth->bind_param(":create_time", strftime('%Y-%m-%d %H:%M:%S', localtime())); $sth->bind_param(":member_id", $msg->{USERID}); $sth->bind_param(":audit_state", 0); $sth->bind_param(":audit_type", 1); #$row->{audit_type} $sth->bind_param(":audit_content_origin", $content_nohtml); $sth->bind_param(":publisher_id", $msg->{USERID}); $sth->bind_param(":publisher_nickname", $msg->{NICKNAME}); $sth->bind_param(":publisher_ip", $msg->{USERIP}); $sth->bind_param(":publish_time", $msg->{PUBTIME}); $sth->bind_param(":section", $row->{section}); $sth->bind_param(":message_id", $row->{messageid}); $sth->bind_param(":message_origin", $message_origin); $sth->bind_param(":message_class", $message_class); $sth->bind_param(":message_reprint", $row->{contenttype}); $sth->bind_param(":content_id", $msg->{CONTENTID}); $sth->bind_param(1, $msg->{CONTENT}); $sth->bind_param(":context_id", $msg->{CONTEXTID}); $sth->bind_param(":context", $msg->{CONTEXT}); $sth->bind_param(":order_type", $row->{priority}); $sth->bind_param(":user_type", $msg->{USERTYPE}); $sth->bind_param_inout(":record_id", \my $new_id, 1e17); $sth->execute; if ($dbh->err()) { # 写入保存失败的新增数据 $logger->debug("store to the file:".$config{restoreDirectory}."/saved.dat"); #my $db = DBM::Deep->new( # file => $config{restoreDirectory}."/saved.dat", # type => DBM::Deep->TYPE_ARRAY # ); #my $len = $db->length(); #$db->put($len, $row); $logger->error($dbh->errstr(enter code here 其中AUDIT_CONTENT为超过4000字符的字段,oracle使用的是clob。 运行报错为ORA-01461: can bind a LONG value only for insert into a LONG column (DBD ERROR: OCIStmtExecute) 查询过java在处理这个种情况的时候是调用的oracle的组件,php在处理这个情况的时候使用 php_oci扩展,问下perl在遇到这种情况下有什么解决方案,在不拆字段,不组装数据的前提下
SQLException: ORA-29861: 域索引标记为 LOADING/FAILED/UNUSABLE
CLOB clob = CLOB.createTemporary(connection, true,CLOB.DURATION_SESSION); clob.putString(1, qyzb);//qyzb是字符串 pstmt = connection.prepareStatement(“insert into KC_CKQ_CKQSP_COORD(CASE_CODE,AREA_CODE,ITEM_CODE,COORDINATE,STATUS) values(?,?,?,?,?)”); pstmt.setString(1, caseCode); pstmt.setString(2, areaCode); pstmt.setString(3, itemCode); pstmt.setClob(4, clob); pstmt.setString(5, status); pstmt.executeUpdate();//执行此处时报错 java.sql.SQLException: ORA-29861: 域索引标记为 LOADING/FAILED/UNUSABLE at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112) 大概是因为clob类型的原因吧,能改为使用setString()吗
数据库查出来的数据,丢失换行回车符
各位大佬好!<br> 最近遇到一个丢失回车换行符的问题,<br> 而且是在四套相同环境的其中一套环境出现问题,其他三套环境都没有问题,很纳闷,所以请教一下各位大佬!<br> 问题如下:<br> 1.编写了一个SQL并按pl/sql格式化过,通过java保存到数据库的clob字段。<br> 2.数据库查询,可以看到正确的格式化过的SQL,即有缩进,有回车换行之类的符号。<br> 3.再次查询该字段的SQL信息展示到前台页面。<br> 4.四套环境都是Linux (red hat 4.4.7-16)WebSphere 8.5.5.7 + oracle11g,其中三套环境页面展示完全正常,该有的格式都有,但是有一套环境的格式全部没有了,所有字符产连成一行。<br> 调试的时候发现这个环境查询出来就没有换行符了,各位大佬有没有遇到过这种情况?麻烦大佬帮忙分析一下原因,小弟感激不尽!!
关于在oracle的function中动态创建表结构的问题~~~
create or replace function jfids.sys_createobjectcopy ( puser in varchar2, --用户或schama ptype in varchar2, --对象类型=table,view,function,...etc pobjectname in varchar2, --对象名称 pdestuser in varchar2 --目标用户或schama ) return number is /****************************************************************************** NAME: sys_createobjectcopy PURPOSE: 根据已知的对象创建对象副本(从一个表空间到另一个表空间) REVISIONS: Ver Date Author Description --------- ---------- --------------- ------------------------------------ 1.0 2012/3/15 showgo 1. Created this function. NOTES: Automatically available Auto Replace Keywords: Object Name: sys_createobjectcopy Sysdate: 2012/3/15 Date and Time: 2012/3/15, 16:28:23, and 2012/3/15 16:28:23 Username: showgo (set in TOAD Options, Procedure Editor) Table Name: (set in the "New PL/SQL Object" dialog) ******************************************************************************/ --vars retcode integer; vcursor integer; vcnt integer; --clob to varchar2 array vscript clob; vscriptblob blob; vtmpblob blob; loblen integer; buffer integer := 4000; vsql varchar2 (32767 byte); vtmp varchar2 (4000 byte); --call convert blob param dest_offset integer; src_offset integer; lang_ctx integer := dbms_lob.default_lang_ctx; warning integer; --exception script_overlength_exception exception; begin retcode := 0; /* * 参数验证 */ if (puser is null or puser = '') then return 0; end if; if (pdestuser is null or pdestuser = '') then return 0; end if; if (ptype is null or ptype = '') then return 0; end if; if (pobjectname is null or pobjectname = '') then return 0; end if; /* * 取得对象的脚本的字符串(脚本可能很长,故先截取再组装) */ begin vscript := dbms_metadata.get_ddl (ptype, pobjectname, puser); /* vscript := replace (vscript, upper (puser), upper (pdestuser)); dbms_lob.converttoblob (vscriptblob, vscript, dbms_lob.lobmaxsize, dest_offset, src_offset, dbms_lob.default_csid, lang_ctx, warning); */ vscriptblob := sys_clob2blob (vscript); loblen := dbms_lob.getlength (vscriptblob); if (loblen > 0) then vcnt := ceil (loblen / buffer); vsql := ''; for i in 1 .. vcnt loop loblen := dbms_lob.getlength (vscriptblob); if (loblen <= buffer) then buffer := loblen; end if; vtmpblob := dbms_lob.substr (vscriptblob, buffer, 1); vtmp := utl_raw.cast_to_varchar2(utl_raw.convert ( vtmpblob, 'simplified chinese_china.zhs16gbk', 'simplified chinese_china.zhs16gbk')); vscriptblob := dbms_lob.substr (vscriptblob, loblen - buffer, buffer + 1); vsql := vsql || vtmp; end loop; else return 0; end if; /* * 按照脚本创建对象 * 创建之前,需要将原对象中用户(或schama)和表空间替换成新的用户(或schama)和表空间 * 注意: 默认用户及表空间使用的是同一名称. */ --vsql := trim (replace (vsql, puser, pdestuser)); --vcursor := dbms_sql.open_cursor; --dbms_sql.parse (dbms_sql.open_cursor, vsql, dbms_sql.native); --dbms_sql.close_cursor (vcursor); --vsql := TRIM (REPLACE (vsql, puser, pdestuser)); vsql := 'create table ''saas_98304''.tc_sex1(code varchar2(2),text varchar2(8),memo varchar2(80))'; execute immediate vsql; exception when no_data_found then retcode := 0; rollback; when others then retcode := 0; rollback; end; return retcode; exception when no_data_found then retcode := 0; rollback; when others then -- Consider logging the error and then re-raise retcode := 0; rollback; raise; end sys_createobjectcopy; / 类似以上的代码在function中。 背景:此function为用户JFIDS的对象,执行时要求能将用户JFIDS下的某些对象(比如表tc_sex)创建到另一用户saas_98304下。红色字体处为另一函数,未给出(其作用是将一个clob值转换成blob值),绿色字体处是一段测试代码,意思就是运行完后希望能得到在saas_98304用户下一个表tc_sex。貌似在pl/sql环境能正常执行,但是一旦写到function中就要报异常了,另外用户jfids已经有创建表结构的权限了。
BLOB 数据类型 selecte ... for update
在Java中使用for update获取需要更新的BLOB数据类型游标会产生锁,是什么时候释放的呢? 感觉很慢,几分钟不能进行操作,即使数据量很小! [code="java"] .......... Class.forName("oracle.jdbc.driver.OracleDriver").newInstance(); Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@192.168.128.35:1521:accebiz1", "sales", "salesw"); if (conn != null) { System.out.println("数据库连接成功!"); } else { System.out.println("数据库连接失败!"); } PreparedStatement lock = conn.prepareStatement(this.getSql("insertTemplate"));//从自己写的xml文件中取SQL log.debug(this.getSql("insertTemplate")); lock.setInt(1, Integer.parseInt(templateNo)); lock.setString(2, url); lock.setString(3, model); lock.setInt(4, Integer.parseInt(modelXAxis)); lock.setInt(5, Integer.parseInt(priceXAxis)); lock.setInt(6, Integer.parseInt(inventoryXAxis)); lock.setInt(7, Integer.parseInt(descriptionXAxis)); lock.setInt(8, Integer.parseInt(modelYAxis)); lock.setInt(9, Integer.parseInt(priceYAxis)); lock.setInt(10, Integer.parseInt(inventoryYAxis)); lock.setInt(11, Integer.parseInt(descriptionYAxis)); lock.setString(12, postDate); lock.setInt(13, Integer.parseInt(siteinfoNo)); lock.executeUpdate(); lock.close(); PreparedStatement ps = conn.prepareStatement(this.getSql("lockSQL")); ps.setInt(1, Integer.parseInt(templateNo)); ResultSet dataLock = ps.executeQuery(); while (dataLock.next()) { BLOB modelTemplateBlob = (BLOB) dataLock.getBlob("model_template"); log.debug("------------------->" + modelTemplateBlob.getBufferSize()); OutputStream out = modelTemplateBlob.getBinaryOutputStream(); byte[] blob = modelTemplate.getBytes(); out.write(blob, 0, blob.length); out.close(); log.debug("------------------->4" + dataLock.getString("description_x_axis")); // insertBolb(dataLock, "model_template", modelTemplate.getBytes()); insertBolb(dataLock, "price_template", priceTemplate.getBytes()); insertBolb(dataLock, "description_template", inventoryTemplate.getBytes()); insertBolb(dataLock, "inventory_template", descriptionTemplate.getBytes()); } ps.close(); .............. public void insertBolb(ResultSet data, String columeName, byte[] blob) { try { log.debug("------------------->start"); BLOB modelTemplateBlob = (BLOB) data.getBlob(columeName); OutputStream out = modelTemplateBlob.getBinaryOutputStream(); int size = modelTemplateBlob.getBufferSize(); out.write(blob, 0, blob.length); out.close(); } catch (IOException ex) { log.debug(ex.getMessage()); log.debug(ex.getStackTrace()); } catch (SQLException sqle) { log.debug(sqle.getMessage()); System.err.println(sqle.getMessage()); } } [/code] [b]问题补充:[/b] 嗯!是单行锁定哦! 啊? :cry: 需求文档描述的需求是从客户端取得12个参数,其中4个是blob,然后写入数据库同一张表中...呜呜,怎么用servlet一次从客户端取我都没弄不明白,然后需求人员说用request.getParameter(""),我都没晃明白客户端怎么发送的,能用这个方法取,如果是字符串有一般存clob吧?只好当字符串取了然后转byte[]存。现在存发现被锁住好半天.....需求人员说了算,我提出自己的意见,多说几遍我自己觉得自己在放屁, 明年不打算干这鸟程序员了,干满一年也算对得起这第一份工作了 在现行的情况下,存的时候能够用什么方式优化么?
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
win10系统安装教程(U盘PE+UEFI安装)
一、准备工作 u盘,电脑一台,win10原版镜像(msdn官网) 二、下载wepe工具箱  极力推荐微pe(微pe官方下载) 下载64位的win10 pe,使用工具箱制作启动U盘打开软件,   选择安装到U盘(按照操作无需更改) 三、重启进入pe系统   1、关机后,将U盘插入电脑 2、按下电源后,按住F12进入启动项选择(技嘉主板是F12)     选择需要启
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Nginx 软件层面加强Nginx性能优化的面试问答和解决方案
Nginx 软件层面加强Nginx性能优化的面试问答和解决方案 去年我去爱卡汽车面试PHP,一轮和二轮面的都不错,在三轮面到Nginx的时候很多问题当时不知道怎么回答,确实没有深入学习过,花了一段时间的学习,终于能解答Nginx高性能优化的问题了,10月24号为了获得程序员勋章,发布了半个优化笔记,浏览到了1000+,受到这个鼓舞,我抽时间在仔细整理下关于Nginx性能优化的问题,我们从软件说起。...
【管理系统课程设计】美少女手把手教你后台管理
【文章后台管理系统】URL设计与建模分析+项目源码+运行界面 栏目管理、文章列表、用户管理、角色管理、权限管理模块(文章最后附有源码) 1. 这是一个什么系统? 1.1 学习后台管理系统的原因 随着时代的变迁,现如今各大云服务平台横空出世,市面上有许多如学生信息系统、图书阅读系统、停车场管理系统等的管理系统,而本人家里就有人在用烟草销售系统,直接在网上完成挑选、购买与提交收货点,方便又快捷。 试想,若没有烟草销售系统,本人家人想要购买烟草,还要独自前往药...
11月19日科技资讯|华为明日发布鸿蒙整体战略;京东宣告全面向技术转型;Kotlin 1.3.60 发布
「极客头条」—— 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「极客头条」来啦,快来看今天都有哪些值得我们技术人关注的重要新闻吧。扫描上方二维码进入 CSDN App 可以收听御姐萌妹 Style 的人工版音频哟。 一分钟速览新闻点! 6G 专家组成员:速率是 5G 的 10 至 100 倍,预计 2030 年商用 雷军:很多人多次劝我放弃WPS,能坚持下来并不是纯粹的商业决定 ...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n
化繁为简 - 腾讯计费高一致TDXA的实践之路
导语:腾讯计费是孵化于支撑腾讯内部业务千亿级营收的互联网计费平台,在如此庞大的业务体量下,腾讯计费要支撑业务的快速增长,同时还要保证每笔交易不错账。采用最终一致性或离线补...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
Java学习笔记(七十二)—— Cookie
概述 会话技术: 会话:一次会话中包含多次请求和响应 一次会话:浏览器第一次给服务器发送资源请求,会话建立,直到有一方断开为止 功能:在一次会话的范围内的多次请求间,共享数据 方式: 客户端会话技术:Cookie,把数据存储到客户端 服务器端会话技术:Session,把数据存储到服务器端 Cookie 概念:客户端会话技术,将数据存储到客户端 快速入门: 使用步骤: 创建C
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆  每天早上8:30推送 作者| Mr.K   编辑| Emma 来源| 技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯
程序员该看的几部电影
##1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
@程序员,如何花式构建线程?
作者 |曾建责编 | 郭芮出品 | CSDN(ID:CSDNnews)在项目和业务的开发中,我们难免要经常使用线程来进行业务处理,使用线程可以保证我们的业务在相互处理之间可以保证原子性...
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布了 2019年国民经济报告 ,报告中指出:年末中国大陆总人口(包括31个
强烈推荐10本程序员在家读的书
很遗憾,这个鼠年春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终
Linux自学篇——linux命令英文全称及解释
man: Manual 意思是手册,可以用这个命令查询其他命令的用法。 pwd:Print working directory 显示当前目录 su:Swith user 切换用户,切换到root用户 cd:Change directory 切换目录 ls:List files 列出目录下的文件 ps:Process Status 进程状态 mk
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
文章目录1. 前言2. 数据下载3. 数据处理4. 数据可视化 1. 前言 今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。 2月6日追记:本文发布后,腾讯的数据源多次变更u
智力题(程序员面试经典)
NO.1  有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸。给你一台称重精准的天平,怎么找出比较重的那瓶药丸?天平只能用一次。 解法 有时候,严格的限制条件有可能反倒是解题的线索。在这个问题中,限制条件是天平只能用一次。 因为天平只能用一次,我们也得以知道一个有趣的事实:一次必须同时称很多药丸,其实更准确地说,是必须从19瓶拿出药丸进行称重。否则,如果跳过两瓶或更多瓶药
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
Java坑人面试题系列: 包装类(中级难度)
Java Magazine上面有一个专门坑人的面试题系列: https://blogs.oracle.com/javamagazine/quiz-2。 这些问题的设计宗旨,主要是测试面试者对Java语言的了解程度,而不是为了用弯弯绕绕的手段把面试者搞蒙。 如果你看过往期的问题,就会发现每一个都不简单。 这些试题模拟了认证考试中的一些难题。 而 “中级(intermediate)” 和 “高级(ad
Spring Boot 2.x基础教程:使用JdbcTemplate访问MySQL数据库
在第2章节中,我们介绍了如何通过Spring Boot来实现HTTP接口,以及围绕HTTP接口相关的单元测试、文档生成等实用技能。但是,这些内容还不足以帮助我们构建一个动态应用的服务端程序。不论我们是要做App、小程序、还是传统的Web站点,对于用户的信息、相关业务的内容,通常都需要对其进行存储,而不是像第2章节中那样,把用户信息存储在内存中(重启就丢了!)。 对于信息的存储,现在已经有非常非常多...
基于Python的人脸自动戴口罩系统
目录 1、项目背景 2、页面设计 3、器官识别 4、退出系统 1、项目背景 2019年新型冠状病毒感染的肺炎疫情发生以来,牵动人心,举国哀痛,口罩、酒精、消毒液奇货可居。 抢不到口罩,怎么办?作为技术人今天分享如何使用Python实现自动戴口罩系统,来安慰自己,系统效果如下所示: 本系统的实现原理是借助 Dlib模块的Landmark人脸68个关键点检测库轻松识别出人脸五官
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
节后首个工作日,企业们集体开晨会让钉钉挂了
By 超神经场景描述:昨天 2 月 3 日,是大部分城市号召远程工作的第一天,全国有接近 2 亿人在家开始远程办公,钉钉上也有超过 1000 万家企业活跃起来。关键词:十一出行 人脸...
Java基础知识点梳理
Java基础知识点梳理 摘要: 虽然已经在实际工作中经常与java打交道,但是一直没系统地对java这门语言进行梳理和总结,掌握的知识也比较零散。恰好利用这段时间重新认识下java,并对一些常见的语法和知识点做个总结与回顾,一方面为了加深印象,方便后面查阅,一方面为了学好java打下基础。 Java简介 java语言于1995年正式推出,最开始被命名为Oak语言,由James Gosling(詹姆
jQuery实现高仿QQ音乐
几个实现的效果看视频吧: bandicam 2020-02-05 16-28-20-127 动图很是不清楚 github地址奉上:https://github.com/tangmusenLiu/Large-warehouse https://github.com/tangmu
为什么听过很多道理,依然过不好这一生?
记录学习笔记是一个重要的习惯,不希望学习过的东西成为过眼云烟。做总结的同时也是一次复盘思考的过程。 本文是根据阅读得到 App上《万维钢·精英日课》部分文章后所做的一点笔记和思考。学习是一个系统的过程,思维模型的建立需要相对完整的学习和思考过程。以下观点是在碎片化阅读后总结的一点心得总结。
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合
相关热词 c#导入fbx c#中屏蔽键盘某个键 c#正态概率密度 c#和数据库登陆界面设计 c# 高斯消去法 c# codedom c#读取cad文件文本 c# 控制全局鼠标移动 c# temp 目录 bytes初始化 c#
立即提问