LONG类型长值存储oracle数据库number字段中取值发现不正确

1.页面用户输入银行卡位数比较长,所以服务端用long类型装载。
当存入到oracle数据库中时,查看数据变成了科学记数法标记。(网上说没有指定oracle的number字段长度会就会科学计数超过8位还是9位)。然后问题来了.......
当取出库中字段去前端展示时候,发现最后四位都变成了0,有的是最后追加了10000。

例子:
原始值 123457689098221781
存到库中是科学记数法
再次取值 就成了 123457689098220000 或者 1234576890982210000
(奇怪的是导出excel时候,文件中的卡号都是正确的.....)

才疏学浅....请帮忙看看

6个回答

每一个存放数据的地方,不管是数据库中表列,还是应用程序中界面UI,它在展示数据的时候都有长度属性的。就像你这个 long型的数字,有十几位长,在丢失精度的情况下,oracle肯定会用科学计数法的形式 保存。就像在 excel中新建标签页中 你输入18位身份证号,回车默认显示成6.xxxxxxxxxxx*10E2这种形式了。但是字符型的话就不会出现这种情况。就像1楼说的。原始存储类型定义成字符型的,需要在其他地方做数值运算是可以强制转换成数值型

qq_34166594
易燃易爆闻一多 问题是,用户手动输入的卡号java用long值接收然后存储到oracle number类型字段中,当取值后发现字段值错误,但是sql中to_char()这个值,java改为String获取。卡号又显示正确了
一年多之前 回复

银行卡号用VARCHAR类型存储,不要用数值类型。

建议去看下关于浮点数据的精度问题,并不是所有的浮点数都可以还原,记得之前看python时候看到过,浮点数有最大精度,也就是小数点后的最大长度,当数据超过这个长度之后就忽略掉了

你看一下你的oracle表这一列的数据类型是什么?如果是数字类型的,应该是类似于decimal() 或者 numeric()之类的,如果是这两个类型,会有精度和小数位刻度设置,确保该精度设置能够存储你的数据。

银行卡号用数值型是不合适的,建议你用VARCHAR。

问题找到了但是暂时不知道解决方法,用long和String或者BigDecimal接受都是正确的卡号,只不过用注解@responsebody 返回给前端时候超出16为的数据都会变为0.

qq_34166594
易燃易爆闻一多 回复gf0515: 是js的问题,js处理的数值超过15位就不能显示了,不过后端也是用字符处理了。哎 长脑子了
一年多之前 回复
gf0515
Fatal Error 回复易燃易爆闻一多: 把这种数据都用String传递,不要使用值类型,@ResponseBody返回String类型就可以了。不明白为什么要用Long类型,这种不会参与数值计算的参数都建议String传递,保证不变性……
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
oracle中long类型转换为number类型
老项目中表中有一个字段是long类型的,存的是浏览次数,现在需要将浏览次数求和,一个sum()函数,用long是不行的,想转换为number类型的。 试了好多方法都不行。 to_char to_number都不行,建了个临时字段用这个 update table a set a.clicknum_new = clicknum; 也不行。 求大家帮忙解决解决,给点意见。
hibernate oracle数据类型为number,值为null,实体类为Long 为什获取到的值为0
hibernate orcle数据类型为number,值为null,实体类为Long 为什获取到的值为0
请教一个struts2下载oracle数据库blob字段的问题
action: ``` public String download() { Long docId = Long.valueOf(RequestUtil.getParam(request, "docId", new Integer(0))).longValue(); try { inputStream = this.taDocumentService.downLoad(docId); return SUCCESS; } catch (Exception e) { e.printStackTrace(); return ERROR; } } ``` service: public InputStream downLoad(Long docId) { TaDocument taDocument = this.read(docId); String filepath = "E:/" + taDocument.getDocName() +"."+ taDocument.getDocType(); InputStream inputStream = null; try { Blob blob = taDocument.getDocContent(); if(blob != null) { inputStream = blob.getBinaryStream(); FileOutputStream file = new FileOutputStream(filepath); int len = (int) blob.length(); byte[] buffer = new byte[len]; while ( (len = inputStream.read(buffer)) != -1) { file.write(buffer, 0, len); } file.close(); inputStream.close(); } } catch(Exception e) { e.printStackTrace(); } return inputStream; } 配置文件: <package name="taDocument" namespace="/taDocument" extends="power-default"> <action name="*" class="com.power.web.action.manager.TaDocumentAction" method="{1}"> <result name="success" type="stream"> <param name="contentType">application/octet-stream;charset=ISO8859-1</param> <param name="inputName">inputStream</param> <param name="contentDisposition">attachment;filename="${attachmentFileName}"</param> <param name="bufferSize">4096</param> </result> </action> </package> 请问为什么不能正常弹出文件下载框并下载呢?
java 如何保存、读取数据库字段为blob类型的值
java 如何保存、读取javaBean中定义String类型,oracle数据库字段为blob类型的值 这是我的业务逻辑代码 try { String encoding = "GBK"; File file = new File("E:\\workspaceNeuSoft\\tomcat7.0.40\\logs\\localhost.2015-12-07.log"); if (file.isFile() && file.exists()) { // 判断文件是否存在 InputStreamReader read = new InputStreamReader( new FileInputStream(file), encoding);// 考虑到编码格式 BufferedReader bufferedReader = new BufferedReader(read); String lineTxt = null; while ((lineTxt = bufferedReader.readLine()) != null) { // System.out.println(lineTxt); interfaceLog.setFwqIp(ip); interfaceLog.setJkLog(lineTxt); interfaceLogService.createInterfaceLog(interfaceLog); } read.close(); } else { System.out.println("找不到指定的文件"); } } catch (Exception e) { System.out.println("读取文件内容出错"); e.printStackTrace(); } 这个是mybatis中代码 <insert id="save" parameterType="interfaceLog"> <selectKey keyProperty="rowId" order="BEFORE" resultType="long"> SELECT seq_neu_interfacelog_id.NEXTVAL FROM DUAL </selectKey> <![CDATA[ INSERT INTO neu_interfacelog DS (DS.ROW_ID, DS.CREATE_BY, DS.CREATE_DATE, DS.REMARK, DS.FWQ_IP, DS.INTERFACELOG ) VALUES (#{rowId}, #{createBy}, SYSDATE, #{remark}, #{fwqIp}, #{jkLog}) ]]> </insert> 现在控制台报异常 015-12-08 15:00:00,620 INFO org.quartz.plugins.history.LoggingTriggerHistoryPlugin.triggerComplete:432 - Trigger neuSoftWorkPlatform_TRIGGER_GROUP.interfaceLogExpireBean completed firing job neuSoftWorkPlatform_JOB_GROUP.interfaceLogExpire at 15:00:00 12/08/2015 with resulting trigger instruction code: DO NOTHING org.springframework.jdbc.UncategorizedSQLException: ### Error updating database. Cause: java.sql.SQLException: ORA-01465: 无效的十六进制数字 ### The error may exist in file [E:\workspaceNeuSoft\neuSoftWorkPlatform\neuSoftWorkPlatform-biz\target\classes\mybatis\mappers\interfaceLog\InterfaceLogMapper.xml] ### The error may involve com.neusoft.interfaceLog.dao.InterfaceLogDAO.save-Inline ### The error occurred while setting parameters ### SQL: INSERT INTO neu_interfacelog DS (DS.ROW_ID, DS.CREATE_BY, DS.CREATE_DATE, DS.REMARK, DS.FWQ_IP, DS.INTERFACELOG ) VALUES (?, ?, SYSDATE, ?, ?, ?) ### Cause: java.sql.SQLException: ORA-01465: 无效的十六进制数字 ; uncategorized SQLException for SQL []; SQL state [72000]; error code [1465]; ORA-01465: 无效的十六进制数字 ; nested exception is java.sql.SQLException: ORA-01465: 无效的十六进制数字 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.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:71) at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:365) at com.sun.proxy.$Proxy27.insert(Unknown Source) at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:237) at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:79) at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:40) at com.sun.proxy.$Proxy86.save(Unknown Source) at com.neusoft.interfaceLog.service.impl.InterfaceLogServiceImpl.createInterfaceLog(InterfaceLogServiceImpl.java:60) at com.haier.openplatform.showcase.quartz.InterfaceLogExpireJob.execute(InterfaceLogExpireJob.java:52) at org.quartz.core.JobRunShell.run(JobRunShell.java:213) at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:557) Caused by: java.sql.SQLException: ORA-01465: 无效的十六进制数字 at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112) at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:331) at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:288) at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:743) at oracle.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:216) at oracle.jdbc.driver.T4CPreparedStatement.executeForRows(T4CPreparedStatement.java:955) at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1168) at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3285) at oracle.jdbc.driver.OraclePreparedStatement.execute(OraclePreparedStatement.java:3390) at com.haier.openplatform.jdbc.HOPPraparedStatement$3.run(HOPPraparedStatement.java:183) at com.haier.openplatform.jdbc.HOPPraparedStatement$3.run(HOPPraparedStatement.java:180) at com.haier.openplatform.jdbc.HOPPraparedStatement.doProfile(HOPPraparedStatement.java:382) at com.haier.openplatform.jdbc.HOPPraparedStatement.execute(HOPPraparedStatement.java:180) at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:41) at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:66) at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:45) at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:108) at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:75) at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:145) at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:134) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:601) at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:355) ... 9 more
myeclipse反向生成类型问题
myeclipse从oracle数据库反向生成实体类时number类型的数据全都变成了BigDecamal,怎样保证数据库number类型生成的全部为Long类型的呢?
C++ long long类型 能存储的 Fibonacci数列中的最大值
#include <iostream> #include <cstdlib> #include "MTime.h" using namespace std; long long _fibonacci(int i) { if (i == 0) return 0; if (i == 1) return 1; return _fibonacci(i-2) + _fibonacci(i-1); } int main() { ofstream out("fibonacci.txt"); int i = 3; long long maxNum = 0; long long num = 1; int useTime; while (maxNum < num) { MTime start; maxNum = num; num = _fibonacci(i++); MTime end; useTime = end.delta(&start); } out << "Fibonacci数列中" << endl << "能用long long数据类型存储的" << "最大数是第 " << i-1 << " 个数" << endl << "这个数是 " << maxNum << endl << "计算出这个数用时 " << useTime << " 秒" <<endl; cout << "Fibonacci数列中" << endl << "能用long long数据类型存储的" << "最大数是第 " << i-1 << " 个数" << endl << "这个数是 " << maxNum << endl << "计算出这个数用时 " << useTime << " 秒" <<endl; system("pause"); return 0; } 我算是一个C++初学者吧,上面程序是我自己写的。我运行它,一个晚上过去了还是没结果。貌似无限循环了。下班回来用F10测试,发现在“i==40”时还能正常进行,当运行到“i==41”时就一直等待了。我一再检查程序没发现问题出在哪儿。求大神解惑~~~ 另:我在将long long 类型用unsigned char类型替代时程序能正常运行且很快得出结果!
多进程读写long类型值
windows下,一个进程不停地写共享内存的一个long类型变量值,另外一个进程不停地 读取该变量值做if判断,这个时候可能该值既不是0也不是1么?
C++中一个Long类型的字段的值是结构体该怎么赋值喃?
C++中一个Long类型的字段的值是结构体该怎么赋值喃?求大虾解答下。
C#怎么读取oracle的long类型数据?
需要读取oracle视图sql语句,用PL/ Sql读取出来显示是Long类型,点击可以查看到sql,但是用C#程序怎么读取到呢?用OracleDataAdapter加载到DataTable显示是空字符串,用DataReader也显示是字符串类型且也是空字符串,明明查询结果应该是有数据的啊,服了Oracle,简单的结果读取都这么麻烦,望高手指教一下哦,以下附源码: OracleConnection conn = new OracleConnection(connString); string sql1 = string.Format("select text from user_views");//PL Sql中能查到数据,是大文本 //1.用OracleDataAdapter的方式 OracleDataAdapter vAdapter = new OracleDataAdapter(sql1, conn); DataTable vTable = new DataTable(); vAdapter.Fill(vTable); //行数与PL Sql读取的一样,但都是空字符串 this.dataGridView1.DataSource = vTable; //1.用DataReader的方式 var mCommand = new OracleCommand(); mCommand.Connection = conn; mCommand.CommandText = sql1; var tbResult = new DataTable("TB1"); try { conn.Open(); using (var reader = mCommand.ExecuteReader()) { var nFieldCount = reader.FieldCount; for (int intCounter = 0; intCounter < nFieldCount; ++intCounter) { tbResult.Columns.Add(reader.GetName(intCounter), reader.GetFieldType(intCounter)); } var objValues = new object[nFieldCount]; while (reader.Read()) { var t1 = reader.GetFieldType(0); //居然显示是String,但是却读不到字符串,PL/Sql显示是LONG类型 var arr1 = (byte[])reader[0]; //强制转换也不行,会报错:无法将类型为“System.String”的对象强制转换为类型“System.Byte[] var b1 = reader.GetOracleBlob(0); var s1 = reader.GetOracleString(0); var sr = reader.GetStream(0); } } } catch (Exception ex) { } finally { conn.Close(); }
java8stream 求和操作 超出long类型最大值
java8 stream ``` Map<String, Map<String, Double>> avgIdThreadMap = list.stream().collect(groupingBy(CalcTimeObject::getThreadId, groupingBy(CalcTimeObject::getId, averagingLong(CalcTimeObject::getCostTime)))); ``` 根据对象两列分组,对long类型求平均我刚刚试了试 超过long的最大值之后结果就不准确了 如果我想就这一块变成BigDecimal计算的话 该怎么操作
mybatis向oracle数据库中插入数据时,需要返回主键值,
# 这是mapper文件里的插入语句 <insert id="insert" parameterType="com.giantplus.ssm.po.Template" > insert into TEMPLATE (ID, ALLOWIP, BACKGROUNDCOLOR, BUSINESS1, BUSINESS2, BUSINESS3, COPYRIGHT, DEFAULTTEMPLATE, HEADERUPLOAD, IPLOCKTIME, LOGMANAGEMENT, LOGINMODEL, MAXFAILURES, PWLENGTH, PWVALIDPERIOD, STATE, UPLOADMAX, UPLOADTYPE ) values (ID, #{allowip,jdbcType=VARCHAR}, #{backgroundcolor,jdbcType=VARCHAR}, #{business1,jdbcType=VARCHAR}, #{business2,jdbcType=VARCHAR}, #{business3,jdbcType=VARCHAR}, #{copyright,jdbcType=VARCHAR}, #{defaulttemplate,jdbcType=DECIMAL}, #{headerupload,jdbcType=VARCHAR}, #{iplocktime,jdbcType=DECIMAL}, #{logmanagement,jdbcType=VARCHAR}, #{loginmodel,jdbcType=VARCHAR}, #{maxfailures,jdbcType=DECIMAL}, #{pwlength,jdbcType=VARCHAR}, #{pwvalidperiod,jdbcType=DECIMAL}, #{state,jdbcType=DECIMAL}, #{uploadmax,jdbcType=VARCHAR}, #{uploadtype,jdbcType=VARCHAR} ) <selectKey resultType="java.math.BigDecimal" keyProperty="id" order="BEFORE"> select SEQ_TEMPLATE.NEXTVAL AS ID from dual </selectKey> </insert> #这是javabean public class Template { private Integer id; private String allowip; private String backgroundcolor; private String business1; private String business2; private String business3; private String copyright; private Long defaulttemplate; private String headerupload; private Long iplocktime; private String logmanagement; private String loginmodel; private Long maxfailures; private String pwlength; private Long pwvalidperiod; private Long state; private String uploadmax; private String uploadtype; # 这个是数据库表字段 ![图片说明](https://img-ask.csdn.net/upload/201507/12/1436685606_515472.png) #报错信息,我希望它能返回主键值,拜托了 org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.ExecutorException: Error selecting key or setting result to parameter object. Cause: org.apache.ibatis.reflection.ReflectionException: Could not set property 'id' of 'class com.giantplus.ssm.po.Template' with value '69' Cause: java.lang.IllegalArgumentException: argument type mismatch at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:75) at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:371) at com.sun.proxy.$Proxy13.insert(Unknown Source) at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:240) at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:51) at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:52) at com.sun.proxy.$Proxy14.insert(Unknown Source) at com.giantplus.ssm.dao.impl.TemplateDaoImpl.saveTemplate(TemplateDaoImpl.java:17) at com.giantplus.ssm.service.impl.TemplateServiceImpl.saveTemplate(TemplateServiceImpl.java:20) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:317) at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150) 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.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204) at com.sun.proxy.$Proxy18.saveTemplate(Unknown Source) at com.giantplus.ssm.service.impl.TemplateServiceImplTest.testInsert(TemplateServiceImplTest.java:35) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44) at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15) at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41) at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20) at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74) at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83) at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72) at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231) at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:88) at org.junit.runners.ParentRunner$3.run(ParentRunner.java:231) at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:60) at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:229) at org.junit.runners.ParentRunner.access$000(ParentRunner.java:50) at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:222) at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71) at org.junit.runners.ParentRunner.run(ParentRunner.java:292) at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174) at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50) at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197) Caused by: org.apache.ibatis.executor.ExecutorException: Error selecting key or setting result to parameter object. Cause: org.apache.ibatis.reflection.ReflectionException: Could not set property 'id' of 'class com.giantplus.ssm.po.Template' with value '69' Cause: java.lang.IllegalArgumentException: argument type mismatch at org.apache.ibatis.executor.keygen.SelectKeyGenerator.processGeneratedKeys(SelectKeyGenerator.java:90) at org.apache.ibatis.executor.keygen.SelectKeyGenerator.processBefore(SelectKeyGenerator.java:46)
mysql 数据迁移至oracle, 程序查询数据遭遇oracle字段大写问题
场景: 之前系统用mysql数据库,很多数据经过hibernate如此查出 [code="java"] public List<Map<String, Object>> getAllPortalPorletItemLstUnderWorkZoneSiteByWorkZoneSiteId( final long projectId, final long orgRoleId, final long workZoneSiteId) { List<Map<String, Object>> list = this.hibernateTemplate .execute(new HibernateCallback<List<Map<String, Object>>>() { public List<Map<String, Object>> doInHibernate( Session session) throws HibernateException, SQLException { List find = null; String sql = "select t2.* , t1.title ,t1.showTitle, t1.type, t1.isLocal, t1.url,t1.maxUrl,t1.defaultHeight,t1.defaultWidth, t1.status " + "from portal_item as t1,portal_default_workzonesite_item as t2 " + "where t1.status=1 and t1.id=t2.portalItemId and t2.workZoneSiteId='" + workZoneSiteId + "' and t2.projectId='" + projectId + "' and t2.orgRoleId='" + orgRoleId + "'"; SQLQuery query = session.createSQLQuery(sql); query .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); find = query.list(); return find; } }); return list; } [/code] 现在改为oracle之后,表字段全是大写,经过sql查出的放回Map中的key全是大写的, 这个一个Map要传递到action 甚至页面上, 之前key全是mysql中的数据字段(小写,有驼峰规则),现在全变成大写了。 请问,谁有好的解决经验,在DAO这层拿到Map时就把里面的key全转化成之前驼峰规则的key(mysql里的小写)值吗?? 您的回答,是我学习的动力,不甚感激!!
EF6 +ORACLE 生成实体时,number(11)变成long 型了,怎么变成int型
我的ORACLE 中表的字段是NUMBER (11),但是用EF拖取model型,生成的类中,变成long型了,如何使他拖取变成int型 ![图片说明](https://img-ask.csdn.net/upload/201707/26/1501060423_104416.png) ![图片说明](https://img-ask.csdn.net/upload/201707/26/1501060443_414761.png) 我用的是EF 6.1.3 orcle用的是Oracle.ManagedDataAccess, Version=4.121.2.0 Oracle.ManagedDataAccess.EntityFramework, Version=6.121.2.0, Vs使用的是2013
C# 如何将一个类中全部字段添加到List中(字段为自定义类,引用类型,不是值类型)?
自定义了一个类,里面包含了很多字段(也是自定义的类),如何将类中的字段全部添加到list中 做这个功能主要是为了能够通过list来访问FileInfoInIni,调用FileInfoInIni的方法。 或者哪位大神有更好的办法能实现这个功能也行 ``` class SystemParamClass { public String ModelFileSavePathName = "D:/Data/SystemParam";//保存参数的文件夹名称 public String ModelSystemParamFileName = "/SystemParam.ini"; public List<FileInfoInIni> AllIniParam = new List<FileInfoInIni>(); public FileInfoInIni LeftDownCamGrapImageHeight; public FileInfoInIni LeftDownCamGrapImagePoseX; public FileInfoInIni LeftDownCamGrapImagePoseY; public FileInfoInIni RightDownCamGrapImageHeight public FileInfoInIni RightDownCamGrapImagePoseX; public FileInfoInIni RightDownCamGrapImagePoseY; } ``` 如何写一个方法,自动将 FileInfoInIni 全部添加到 AllIniParam 中 FileInfoInIni  为自定义的类,我试过了反射,只能设置值,不知道怎么转换类型,然后添加进去 ``` public static void AddTolist(object TempClass) { Type t = TempClass.GetType(); FieldInfo[] fields = t.GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Static | BindingFlags.Public); foreach (FieldInfo field in fields) { if (field.FieldType == typeof(FileInfoInIni)) { Console.WriteLine("Field:" + field); Console.WriteLine("Field:" + field.Name ); } //Console.WriteLine("Field:" + field); } } ``` 不能强制转换类型 ![图片说明](https://img-ask.csdn.net/upload/201911/15/1573789359_269905.jpg) FileInfoInIni的定义 ``` public class FileInfoInIni { private string FilePathAndName; private string FileSection; private string FileAppName; public object Value; public string Key { get => FileAppName; } [DllImport("kernel32", CharSet = CharSet.Ansi, EntryPoint = "GetPrivateProfileStringA", ExactSpelling = true, SetLastError = true)] private static extern int GetPrivateProfileString([MarshalAs(UnmanagedType.VBByRefStr)] ref string lpApplicationName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpKeyName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpDefault, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpReturnedString, int nSize, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpFileName); [DllImport("kernel32", CharSet = CharSet.Ansi, EntryPoint = "WritePrivateProfileStringA", ExactSpelling = true, SetLastError = true)] private static extern int WritePrivateProfileString([MarshalAs(UnmanagedType.VBByRefStr)] ref string lpApplicationName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpKeyName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpString, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpFileName); public string GetINI(string Section, string AppName, string lpDefault, string FileName) { string text = Strings.LSet("", 256); FileInfoInIni.GetPrivateProfileString(ref Section, ref AppName, ref lpDefault, ref text, Strings.Len(text), ref FileName); return Strings.Left(text, checked(Strings.InStr(text, "\0", CompareMethod.Binary) - 1)); } public long WriteINI(string Section, string AppName, string lpDefault, string FileName) { return (long)FileInfoInIni.WritePrivateProfileString(ref Section, ref AppName, ref lpDefault, ref FileName); } public bool ReadValue() { bool result; try { this.Value = this.GetINI(this.FileSection, this.FileAppName, "", this.FilePathAndName); bool flag = Operators.ConditionalCompareObjectEqual(this.Value, "", false); if (flag) { result = false; return result; } } catch (Exception expr_41) { ProjectData.SetProjectError(expr_41); result = false; ProjectData.ClearProjectError(); return result; } result = true; return result; } public bool SaveValue() { bool result; try { string left = this.Value.ToString(); this.WriteINI(this.FileSection, this.FileAppName, Conversions.ToString(this.Value), this.FilePathAndName); string iNI = this.GetINI(this.FileSection, this.FileAppName, "", this.FilePathAndName); bool flag = Operators.CompareString(left, iNI, false) != 0; if (flag) { result = false; return result; } } catch (Exception expr_71) { ProjectData.SetProjectError(expr_71); result = false; ProjectData.ClearProjectError(); return result; } result = true; return result; } public FileInfoInIni(string TempFilePathAndName, string TempFileSection, string TempFileAppName) { this.Value = RuntimeHelpers.GetObjectValue(new object()); this.FilePathAndName = TempFilePathAndName; this.FileSection = TempFileSection; this.FileAppName = TempFileAppName; this.Value = null; } public void dispose() { this.FilePathAndName = ""; this.FileSection = ""; this.FileAppName = ""; this.Value = null; } } ```
关于ORACLE long raw 转blob问题
有一张T1表,里面有字段long raw类型,用于存放图片。现在要将T1表里的数据放到T2表中,T2表用于存放图片的类型是BLOB。 insert into T2 as select * from T1; 报错.T1表中的long raw类型不能传。 请问有什么方法可以将T1中图片传到T2中.
Java方法中一个返回值类型为基本数据类型long,return语句可以是一个对象吗
Java方法中一个返回值类型为基本数据类型long,return语句可以是一个对象吗
求助,VS下用ODBC链接不上oracle数据库
初学数据库,SQLConnect调用总是出错,查了一下发现一个跟我类似情况的 文章链接:http://bbs.csdn.net/topics/390017214,但是题主也没说解决了没有,我按照评论里说的做了可是还是出错。数据源也配置且测试成功,数据库用的oracle12g。 代码如下: ``` #include<stdlib.h> #include<stdio.h> #include<windows.h> #include<sql.h> #include<sqlext.h> #include<Sqltypes.h> //using System.Data.Sqlclient /*#include<odbcinst.h > #include <odbcss.h> #pragma comment(lib,"odbc32.lib")*/ #define SNO_LEN 30 #define NAME_LEN 50 #define DEPART_LEN 100 #define SGENDER_LEN 5 int main(){ SQLHENV oraclehenv; SQLHDBC oraclehdbc; SQLHSTMT oraclehstmt; SQLRETURN ret; SQLCHAR sName[NAME_LEN], sDepart[DEPART_LEN], sGender[SGENDER_LEN], sSno[SNO_LEN]; //SQLCHAR oracleName[] = "Oracle", stmt[] = "INSERT INTO STUDENT (SNO,SNAME,SSEX,SAGE,SDEPT)VALUES(?,?,?,?,?)"; SQLINTEGER sAge; SQLINTEGER cbAge = 0, cbSno = SQL_NTS, cbGender = SQL_NTS, cbName = SQL_NTS, cbDepart = SQL_NTS; /*初始化环境*/ ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &oraclehenv); ret = SQLSetEnvAttr(oraclehenv, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0); /*建立连接*/ ret = SQLAllocHandle(SQL_HANDLE_DBC, oraclehenv, &oraclehdbc); ret = SQLConnect(oraclehdbc, (SQLCHAR*)"Oracle", SQL_NTS, (SQLCHAR*)"c##admin", SQL_NTS, (SQLCHAR*)"admin", SQL_NTS); if (!SQL_SUCCEEDED(ret)) { printf("数据库连接失败!\n"); system("pause"); return -1; } /*初始化语句句柄*/ ret = SQLAllocHandle(SQL_HANDLE_STMT, oraclehdbc, &oraclehstmt); ret = SQLExecDirect(oraclehstmt, (SQLCHAR*)"SELCET * FROM STUDENT", SQL_NTS); if (ret==SQL_SUCCESS||ret==SQL_SUCCESS_WITH_INFO) { ret = SQLBindCol(oraclehstmt, 1, SQL_C_CHAR, sSno, SNO_LEN, &cbSno); ret = SQLBindCol(oraclehstmt, 2, SQL_C_CHAR, sName, NAME_LEN, &cbName); ret = SQLBindCol(oraclehstmt, 3, SQL_C_CHAR, sGender, SGENDER_LEN, &cbGender); ret = SQLBindCol(oraclehstmt, 4, SQL_C_LONG, &sAge, 0, &cbAge); ret = SQLBindCol(oraclehstmt, 5, SQL_C_CHAR, sDepart, DEPART_LEN, &cbDepart); //printf("%s,%s,%s,%d,%s\n", cbSno, cbName, cbGender, cbAge, cbDepart); } while ((ret = SQLFetch(oraclehstmt)) != SQL_NO_DATA_FOUND) { if (ret == SQL_ERROR) printf("Fetch error\n"); else printf("%s,%s,%s,%d,%s\n", cbSno, cbName, cbGender, cbAge, cbDepart); } SQLFreeHandle(SQL_HANDLE_STMT, oraclehstmt); SQLDisconnect(oraclehdbc); SQLFreeHandle(SQL_HANDLE_DBC, oraclehdbc); SQLFreeHandle(SQL_HANDLE_STMT, oraclehenv); system("pause"); return 0; } ```
oracle中设置了自增id,安卓客户端要读取这个值,用int够不够大?
oracle中设了自增主键,没设置maxvalue的值。服务器把数据记录发给安卓客户端,每条记录包括自增主键的值。在安卓客户端将这个值保存到int或long类型变量中够不够?
从数据库读取字节数组的问题。
从Oracle数据库读取Long Raw列里面存储的图片。发现读取到的字节数组长度为0,而那条Select语句,却可以在Oracle SQL Developer 里面查找到一大串字符串。。。。。。。很长很长的字符串。以前往Oracle里面存MP3,然后取出来。也是可以创建MP3文件,但是文件长度为0,估计也是这个因为从Oracle里面取出来的二进制字节数组,长度为0的原因。 求解答: 1.为什么取出来的字节数组长度为0,而我数据库里面明明有数据,SQL语句又没有问题。 2.怎么解决这个问题。 我的部分代码如下图。 ![图片](https://img-ask.csdn.net/upload/201508/05/1438746198_43801.jpg)
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
相关热词 c#如何定义数组列表 c#倒序读取txt文件 java代码生成c# c# tcp发送数据 c#解决时间格式带星期 c#类似hashmap c#设置istbox的值 c#获取多线程返回值 c# 包含数字 枚举 c# timespan
立即提问