- 【YashanDB 知识库】JDBC 驱动的 date 类型字段结果集调用 getString 方法只返回日期,不返回时分秒
数据库date
问题现象JDBC驱动查询date类型字段,对ResultSet直接调用getString方法,驱动返回的字符串只有日期,没有时分秒。如上Java代码片断只返回YYYY-MM-DD类型的字符串,没有带时分秒问题的风险及影响返回的字符串只有日期,没有时分秒,影响业务逻辑。问题影响的版本所有的YashanDB驱动。问题发生原因YashanDB驱动内部实现问题。解决方法及规避方式使用rs.getTimes
- 一次使用JDBC流式读取MYSQL数据库引发MYSQL服务性能问题的分析
eaglesstone
mysql数据库数据库mysql
背景:因公司业务需要,需要将mysql数据库中的一些数据放到redis中进行缓存,以提高查询效率。首先需要将存量数据初始化到redis中,现有存量数据约1000w,同事开发了个java小程序使用stmt.setFetchSize(Integer.MIN_VALUE)结合ResultSet.TYPE_FORWARD_ONLY和ResultSet.CONCUR_READ_ONLY模式的流式读取方式,将
- 通过 `ResultSet` 对象的方法来获取其中的行和列的数据
有人给我介绍对象吗
#JDBCoracle数据库
在JDBC中,使用ResultSet对象来存储从数据库查询返回的结果集。你可以通过ResultSet对象的方法来获取其中的行和列的数据。以下是一些常见的方法:获取列的数据:通过列名获取数据:ResultSetresultSet=statement.executeQuery("SELECTcolumn1,column2FROMmy_table");while(resultSet.next()){St
- 数据库学习记录 Day2(JDBC)
赈川
JDBCJDBCMySqlJava
文章目录Day2JDBC简介JDBC的流程DriverManagerl类数据库URL详解Connection类ResultSet类释放资源Statement对象介绍CRUD操作建立JDBC工具类Day22019年7月6日。这是我学习数据库的第二天。这一天,我学到了以下的知识。JDBC简介JDBC(JavaDatabaseConnectivity),SUN公司为了简化、统一对数据库的操作,定义了一套
- JDBC ResultSet解析(转载)
pascalzhli
mysqljava
结果集(ResultSet)是数据中查询结果返回的一种对象,可以说结果集是一个存储查询结果的对象,但是结果集并不仅仅具有存储的功能,他同时还具有操纵数据的功能,可能完成对数据的更新等。结果集读取数据的方法主要是getXXX(),他的参数可以使整型表示第几列(是从1开始的),还可以是列名。返回的是对应的XXX类型的值。如果对应那列时空值,XXX是对象的话返回XXX型的空值,如果XXX是数字类型,如F
- Mybatis源码学习(七)——ResultSetHandler 结果处理
Laplaces Demon
mybatis学习
通过之前对StatementHandler类(Mybatis源码学习(五)——StatementHandler-CSDN博客)的分析发现在所有StatementHandler接口的实现类,无论是PreparedStatementHandler、CallableStatementHandler还是SimpleStatementHandler都是使用ResultSetHandler对象对结果(包括Li
- 第 3 章 核心处理层(中)
沉登c
MyBatis技术内幕mybatisjava
3.3ResultSetHandlerMyBatis将结果集按照映射配置文件中定义的映射规则,例如节点、resultType属性等,映射成相应的结果对象。这一过程是由ResultSetHandler完成的。publicinterfaceResultSetHandler{//处理结果集,生成相应的结果对象集合ListhandleResultSets(Statementstmt)throwsSQLEx
- 【JAVA 基础 第(20)课】JDBC JAVA 连接 MySql 数据库
黑口罩
【JAVA】系列java
pom.xml导入MySqljar包mysqlmysql-connector-java5.1.30数据库驱动、连接封装成一个工具类DBUtil类importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.sql.State
- rds mysql 8.0_新功能初探 | RDS MySQL 8.0 支持 DML 语句 returning
伊瓦的战士莱曼
rdsmysql8.0
背景MySQL对于statement执行结果报文通常分为两类Resultset和OK/ERR,针对DML语句则返回OK/ERR报文,其中包括几个影响记录,扫描记录等属性。但在很多业务场景下,通常INSERT/UPDATE/DELETE这样的DML语句后,都会跟随SELECT查询当前记录内容,以进行接下来的业务处理,为了减少一次ClientDBServer交互,类似PostgreSQL/Oracle
- mybatis与gbase8s plsql适配问题一
gbase_lmax
gbase8s数据库
在使用mybatis调用gbase8soracle模式下创建的plsql时,出现空指针的报错Causedby:java.lang.NullPointerExceptionatcom.gbasedbt.jdbc.IfxCallableStatement.getResultSet(IfxCallableStatement.java:267)atorg.apache.ibatis.executor.re
- JDBC
yulijun6943
javajdbcjavamysql数据库大数据
JDBC一概念二JDBC开发步骤【`重点`】三ResultSet(结果集)3.1接收结果集3.2遍历ResultSet中的数据3.3常见错误四PreparedStatement【`重点`】4.1PreparedStatement的应用4.1.1动态参数绑定五封装工具类5.1重用性方案5.2跨平台方案5.2.1六ORM6.1实体类(entity):零散数据的载体七DAO数据访问对象(DataAcce
- 15.1:Java与Oracle数据库的集成基础(JDBC)(课程共6100字,4个代码举例)
小兔子平安
Java完整学习全解答oracle数据库java
①连接数据库并查询数据②插入数据③更新数据④删除数据①连接数据库并查询数据importjava.sql.*;publicclassJdbcDemo{publicstaticvoidmain(String[]args){Connectionconn=null;Statementstmt=null;ResultSetrs=null;Stringurl="jdbc:oracle:thin:@localh
- java preparedStatement 查询案例
2401_83232029
java开发语言
packagejdbc.Test;importjdbc.Utils.jdbc_Utils;importorg.junit.Test;importjava.sql.Connection;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.util.Scanne
- JDBC查询案例
2401_83232029
windowslinuxmicrosoft
1、封装javabean/实体类Persion{属性方法}让属性不可以直接获取,得到方法(get/set)得到封装的时候针对的是表,所以我们的实体类的所有的属性都要和表中的字段对应回忆(*****):集合:存储各种数据类型。List常用,存放对象add();集合的对象读结果集存储Listlist=newArrayList();while(resultSet.next()){//System.out
- java源码学习-Mybatis(2)与数据库建立连接
子波zibo
源码学习java基础mybatisjavajdbc
Mybatis与数据库建立连接jdbc执行流程图Mybatis初始化Hikari连接池的启动Mybatis获取数据库连接后记前文:Mybatis加载mapper流程由于mybatis是在jdbc的基础上进行封装的,所以jdbc执行流程获取连接->创建statements->resultSet这些步骤mybatis都是存在的,本篇学习一下Mybatis获取Connection的步骤jdbc执行流程图
- Goods的Dao类
Joy_yang17
packagecom.nsu.dao;importjava.sql.Connection;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.util.ArrayList;importorg.eclipse.swt.internal.win32.UDACCEL;importcom.nsu.bean.Goods;import
- JavaWeb学习(一)---MySQL数据库
肥大毛
Java学习数据库mysql学习
文章目录MySQL查询中嵌套查询,称嵌套查询为子查询事务事务的四大特性数据库引擎存储过程变量函数触发器JDBCJDBC详解DriverManager驱动管理类Connection数据库连接对象Statementsql执行ResultSet:结果集对象PreparedStatement:预编译SQL语句并且执行,预防SQL注入问题在sql语句中?代表占位符数据库连接池练习:基于Druid连接池实现对
- JDBC实现增删改查(简单的学生管理系统)
小言不爱说
数据库服务器java
JDBC实现增删改查(简单的学生管理系统)题目描述:1.请编程实现基于数据库的学生信息管理程序,程序的功能有:显示所有学生、新增学生、删除学生、修改学生、查找学生(根据学号、姓名、班级、性别、专业、学院等),程序采用命令行方式。2.请编程实现把从数据库中查询出的学生信息记录集(ResultSet)中的记录转换为学生对象。实现过程1、JDBC安装下载下载jar包,官网链接为:链接:官网链接下载文件:
- 【Java】笔记:JDBC中Statement常用的几个执行函数
a辰龙a
java笔记开发语言
1.executeQuery(Stringsql):ResultSet用于执行查询语句(SELECT),返回一个ResultSet对象,该对象包含了查询结果的数据。可以通过ResultSet提供的方法来获取查询结果。//声明statementStatementstatement=connection.createStatement();//发送查询语句ResultSetresultSet=stat
- Hive 在 Join 查询时报错: Bad status for request TFetchResultsReq ...
lei_charles
异常信息:BadstatusforrequestTFetchResultsReq(fetchType=1,operationHandle=TOperationHandle(hasResultSet=True,modifiedRowCount=None,operationType=0,operationId=THandleIdentifier(secret='\xff\xe1\x85\x867JMQ
- Mybatis源码阅读之三——JDBC解析与Mybatis封装
JAVA技术分享官
Mybatis源码阅读系列JDBCmybatis源码
【系列目录】Mybatis源码阅读之一——工厂模式与SqlSessionFactoryMybatis源码阅读之二——模板方法模式与Executor【本文目录】文章目录一.JDBCDemoJDBC实体解析二.mysql-connectorDriver获取Connection,Mysql驱动的负载策略StatementResultSet二.Mybatis的封装StatementHandlerResul
- sql注入例子
月球的企鹅
packagecn.itheima.test;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.sql.Statement;importorg.j
- servlet连接mysql数据库和oracle数据库
浪羽
连接mysql数据库packagedao;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.sql.Statement;publicclassBaseDao{//连接mysql数据库Connection
- 单元测试Mockito使用及详解
熊與猫v
Java单元测试junitjava
一、什么是MOCK测试Mock测试就是在测试过程中,对于某些不容易构造(如HttpServletRequest必须在Servlet容器中才能构造出来)或者不容易获取比较复杂的对象(如JDBC中的ResultSet对象),用一个虚拟的对象(Mock对象)来创建以便测试的测试方法。Mock最大的功能是帮你把单元测试的耦合分解开,如果你的代码对另一个类或者接口有依赖,它能够帮你模拟这些依赖,并帮你验证所
- java.sql.SQLFeatureNotSupportedException解决方法
rivercoder
JavaMySQLQ&AjavaDruidMybatis-Plus
使用MyBatis访问数据库查询数据时报错:Causedby:java.sql.SQLFeatureNotSupportedExceptionatcom.alibaba.druid.pool.DruidPooledResultSet.getObject(DruidPooledResultSet.java:1771)atsun.reflect.NativeMethodAccessorImpl.inv
- java mysql 流式读取_JDBC流式读取MySQL表
weixin_40001805
javamysql流式读取
一张MySQL大表,我们希望遍历表中的数据,一般情况下都是一次性读进内存中,这样就会给服务器增大很大的压力,那我们可以不可以流式读取MySQL表呢,就像ElasticSearch的scrollSearch一样的效果。答案是可以的。经过看Statement的源码找到了如下片段:/***Weonlystreamresultsetswhentheyareforward-only,read-only,an
- java mysql并发 流_Mysql中使用JDBC流式查询避免数据量过大导致OOM
weixin_39595008
javamysql并发流
一、前言java中MySQLJDBC封装了流式查询操作,通过设置几个参数,就可以避免一次返回数据过大导致OOM。二、如何使用2.1之前查询publicvoidselectData(StringsqlCmd)throwsSQLException{validate(sqlCmd);Connectionconn=null;PreparedStatementstmt=null;ResultSetrs=nu
- MySQL 流式读取_使用MySQL流式传输大型结果集
山同气
MySQL流式读取
我正在开发一个使用大型MySQL表的spring应用程序。加载大表时,我得到一个OutOfMemoryException,因为驱动程序试图将整个表加载到应用程序内存中。我尝试使用statement.setFetchSize(Integer.MIN_VALUE);但是然后我打开的每个ResultSet都挂了close();在网上查找时,我发现发生这种情况是因为它尝试在关闭ResultSet之前尝试加
- Java 错误 Operation Not Allowed After ResultSet Closed
迹忆客
Javajava开发语言
本篇文章介绍了Java中的java.sql.SQLException:OperationnotallowedafterResultSetclosed错误。Java错误java.sql.SQLException:OperationnotallowedafterResultSetclosed当我们尝试访问关闭的结果集时,错误“结果集关闭后不允许操作”是一个SQL异常。正如JavaDoc提到的,每当一个
- Java.sql.SQLException: Illegal operation on empty result set.
骚戴
烦人的Bugjavasql数据库
报错信息:Java.sql.SQLException:Illegaloperationonemptyresultset.报错原因:查询的结果集ResultSet是空的,通常是数据库里没有对应的数据或者没有数据导致的,然后你又用了rs.getString("")或者rs==null或者rs.equals("")来判断ResultSet是否为空,所以就报这个错误了解决办法:通过rs.next()来判断
- ASM系列五 利用TreeApi 解析生成Class
lijingyao8206
ASM字节码动态生成ClassNodeTreeAPI
前面CoreApi的介绍部分基本涵盖了ASMCore包下面的主要API及功能,其中还有一部分关于MetaData的解析和生成就不再赘述。这篇开始介绍ASM另一部分主要的Api。TreeApi。这一部分源码是关联的asm-tree-5.0.4的版本。
在介绍前,先要知道一点, Tree工程的接口基本可以完
- 链表树——复合数据结构应用实例
bardo
数据结构树型结构表结构设计链表菜单排序
我们清楚:数据库设计中,表结构设计的好坏,直接影响程序的复杂度。所以,本文就无限级分类(目录)树与链表的复合在表设计中的应用进行探讨。当然,什么是树,什么是链表,这里不作介绍。有兴趣可以去看相关的教材。
需求简介:
经常遇到这样的需求,我们希望能将保存在数据库中的树结构能够按确定的顺序读出来。比如,多级菜单、组织结构、商品分类。更具体的,我们希望某个二级菜单在这一级别中就是第一个。虽然它是最后
- 为啥要用位运算代替取模呢
chenchao051
位运算哈希汇编
在hash中查找key的时候,经常会发现用&取代%,先看两段代码吧,
JDK6中的HashMap中的indexFor方法:
/**
* Returns index for hash code h.
*/
static int indexFor(int h, int length) {
- 最近的情况
麦田的设计者
生活感悟计划软考想
今天是2015年4月27号
整理一下最近的思绪以及要完成的任务
1、最近在驾校科目二练车,每周四天,练三周。其实做什么都要用心,追求合理的途径解决。为
- PHP去掉字符串中最后一个字符的方法
IT独行者
PHP字符串
今天在PHP项目开发中遇到一个需求,去掉字符串中的最后一个字符 原字符串1,2,3,4,5,6, 去掉最后一个字符",",最终结果为1,2,3,4,5,6 代码如下:
$str = "1,2,3,4,5,6,";
$newstr = substr($str,0,strlen($str)-1);
echo $newstr;
- hadoop在linux上单机安装过程
_wy_
linuxhadoop
1、安装JDK
jdk版本最好是1.6以上,可以使用执行命令java -version查看当前JAVA版本号,如果报命令不存在或版本比较低,则需要安装一个高版本的JDK,并在/etc/profile的文件末尾,根据本机JDK实际的安装位置加上以下几行:
export JAVA_HOME=/usr/java/jdk1.7.0_25  
- JAVA进阶----分布式事务的一种简单处理方法
无量
多系统交互分布式事务
每个方法都是原子操作:
提供第三方服务的系统,要同时提供执行方法和对应的回滚方法
A系统调用B,C,D系统完成分布式事务
=========执行开始========
A.aa();
try {
B.bb();
} catch(Exception e) {
A.rollbackAa();
}
try {
C.cc();
} catch(Excep
- 安墨移动广 告:移动DSP厚积薄发 引领未来广 告业发展命脉
矮蛋蛋
hadoop互联网
“谁掌握了强大的DSP技术,谁将引领未来的广 告行业发展命脉。”2014年,移动广 告行业的热点非移动DSP莫属。各个圈子都在纷纷谈论,认为移动DSP是行业突破点,一时间许多移动广 告联盟风起云涌,竞相推出专属移动DSP产品。
到底什么是移动DSP呢?
DSP(Demand-SidePlatform),就是需求方平台,为解决广 告主投放的各种需求,真正实现人群定位的精准广
- myelipse设置
alafqq
IP
在一个项目的完整的生命周期中,其维护费用,往往是其开发费用的数倍。因此项目的可维护性、可复用性是衡量一个项目好坏的关键。而注释则是可维护性中必不可少的一环。
注释模板导入步骤
安装方法:
打开eclipse/myeclipse
选择 window-->Preferences-->JAVA-->Code-->Code
- java数组
百合不是茶
java数组
java数组的 声明 创建 初始化; java支持C语言
数组中的每个数都有唯一的一个下标
一维数组的定义 声明: int[] a = new int[3];声明数组中有三个数int[3]
int[] a 中有三个数,下标从0开始,可以同过for来遍历数组中的数
- javascript读取表单数据
bijian1013
JavaScript
利用javascript读取表单数据,可以利用以下三种方法获取:
1、通过表单ID属性:var a = document.getElementByIdx_x_x("id");
2、通过表单名称属性:var b = document.getElementsByName("name");
3、直接通过表单名字获取:var c = form.content.
- 探索JUnit4扩展:使用Theory
bijian1013
javaJUnitTheory
理论机制(Theory)
一.为什么要引用理论机制(Theory)
当今软件开发中,测试驱动开发(TDD — Test-driven development)越发流行。为什么 TDD 会如此流行呢?因为它确实拥有很多优点,它允许开发人员通过简单的例子来指定和表明他们代码的行为意图。
TDD 的优点:
&nb
- [Spring Data Mongo一]Spring Mongo Template操作MongoDB
bit1129
template
什么是Spring Data Mongo
Spring Data MongoDB项目对访问MongoDB的Java客户端API进行了封装,这种封装类似于Spring封装Hibernate和JDBC而提供的HibernateTemplate和JDBCTemplate,主要能力包括
1. 封装客户端跟MongoDB的链接管理
2. 文档-对象映射,通过注解:@Document(collectio
- 【Kafka八】Zookeeper上关于Kafka的配置信息
bit1129
zookeeper
问题:
1. Kafka的哪些信息记录在Zookeeper中 2. Consumer Group消费的每个Partition的Offset信息存放在什么位置
3. Topic的每个Partition存放在哪个Broker上的信息存放在哪里
4. Producer跟Zookeeper究竟有没有关系?没有关系!!!
//consumers、config、brokers、cont
- java OOM内存异常的四种类型及异常与解决方案
ronin47
java OOM 内存异常
OOM异常的四种类型:
一: StackOverflowError :通常因为递归函数引起(死递归,递归太深)。-Xss 128k 一般够用。
二: out Of memory: PermGen Space:通常是动态类大多,比如web 服务器自动更新部署时引起。-Xmx
- java-实现链表反转-递归和非递归实现
bylijinnan
java
20120422更新:
对链表中部分节点进行反转操作,这些节点相隔k个:
0->1->2->3->4->5->6->7->8->9
k=2
8->1->6->3->4->5->2->7->0->9
注意1 3 5 7 9 位置是不变的。
解法:
将链表拆成两部分:
a.0-&
- Netty源码学习-DelimiterBasedFrameDecoder
bylijinnan
javanetty
看DelimiterBasedFrameDecoder的API,有举例:
接收到的ChannelBuffer如下:
+--------------+
| ABC\nDEF\r\n |
+--------------+
经过DelimiterBasedFrameDecoder(Delimiters.lineDelimiter())之后,得到:
+-----+----
- linux的一些命令 -查看cc攻击-网口ip统计等
hotsunshine
linux
Linux判断CC攻击命令详解
2011年12月23日 ⁄ 安全 ⁄ 暂无评论
查看所有80端口的连接数
netstat -nat|grep -i '80'|wc -l
对连接的IP按连接数量进行排序
netstat -ntu | awk '{print $5}' | cut -d: -f1 | sort | uniq -c | sort -n
查看TCP连接状态
n
- Spring获取SessionFactory
ctrain
sessionFactory
String sql = "select sysdate from dual";
WebApplicationContext wac = ContextLoader.getCurrentWebApplicationContext();
String[] names = wac.getBeanDefinitionNames();
for(int i=0; i&
- Hive几种导出数据方式
daizj
hive数据导出
Hive几种导出数据方式
1.拷贝文件
如果数据文件恰好是用户需要的格式,那么只需要拷贝文件或文件夹就可以。
hadoop fs –cp source_path target_path
2.导出到本地文件系统
--不能使用insert into local directory来导出数据,会报错
--只能使用
- 编程之美
dcj3sjt126com
编程PHP重构
我个人的 PHP 编程经验中,递归调用常常与静态变量使用。静态变量的含义可以参考 PHP 手册。希望下面的代码,会更有利于对递归以及静态变量的理解
header("Content-type: text/plain");
function static_function () {
static $i = 0;
if ($i++ < 1
- Android保存用户名和密码
dcj3sjt126com
android
转自:http://www.2cto.com/kf/201401/272336.html
我们不管在开发一个项目或者使用别人的项目,都有用户登录功能,为了让用户的体验效果更好,我们通常会做一个功能,叫做保存用户,这样做的目地就是为了让用户下一次再使用该程序不会重新输入用户名和密码,这里我使用3种方式来存储用户名和密码
1、通过普通 的txt文本存储
2、通过properties属性文件进行存
- Oracle 复习笔记之同义词
eksliang
Oracle 同义词Oracle synonym
转载请出自出处:http://eksliang.iteye.com/blog/2098861
1.什么是同义词
同义词是现有模式对象的一个别名。
概念性的东西,什么是模式呢?创建一个用户,就相应的创建了 一个模式。模式是指数据库对象,是对用户所创建的数据对象的总称。模式对象包括表、视图、索引、同义词、序列、过
- Ajax案例
gongmeitao
Ajaxjsp
数据库采用Sql Server2005
项目名称为:Ajax_Demo
1.com.demo.conn包
package com.demo.conn;
import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;
//获取数据库连接的类public class DBConnec
- ASP.NET中Request.RawUrl、Request.Url的区别
hvt
.netWebC#asp.nethovertree
如果访问的地址是:http://h.keleyi.com/guestbook/addmessage.aspx?key=hovertree%3C&n=myslider#zonemenu那么Request.Url.ToString() 的值是:http://h.keleyi.com/guestbook/addmessage.aspx?key=hovertree<&
- SVG 教程 (七)SVG 实例,SVG 参考手册
天梯梦
svg
SVG 实例 在线实例
下面的例子是把SVG代码直接嵌入到HTML代码中。
谷歌Chrome,火狐,Internet Explorer9,和Safari都支持。
注意:下面的例子将不会在Opera运行,即使Opera支持SVG - 它也不支持SVG在HTML代码中直接使用。 SVG 实例
SVG基本形状
一个圆
矩形
不透明矩形
一个矩形不透明2
一个带圆角矩
- 事务管理
luyulong
javaspring编程事务
事物管理
spring事物的好处
为不同的事物API提供了一致的编程模型
支持声明式事务管理
提供比大多数事务API更简单更易于使用的编程式事务管理API
整合spring的各种数据访问抽象
TransactionDefinition
定义了事务策略
int getIsolationLevel()得到当前事务的隔离级别
READ_COMMITTED
- 基础数据结构和算法十一:Red-black binary search tree
sunwinner
AlgorithmRed-black
The insertion algorithm for 2-3 trees just described is not difficult to understand; now, we will see that it is also not difficult to implement. We will consider a simple representation known
- centos同步时间
stunizhengjia
linux集群同步时间
做了集群,时间的同步就显得非常必要了。 以下是查到的如何做时间同步。 在CentOS 5不再区分客户端和服务器,只要配置了NTP,它就会提供NTP服务。 1)确认已经ntp程序包: # yum install ntp 2)配置时间源(默认就行,不需要修改) # vi /etc/ntp.conf server pool.ntp.o
- ITeye 9月技术图书有奖试读获奖名单公布
ITeye管理员
ITeye
ITeye携手博文视点举办的9月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。 9月试读活动回顾:http://webmaster.iteye.com/blog/2118112本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《NFC:Arduino、Andro