mybatis 查询数据库返回值某字段是 List 该怎么搞?

mybatis 查询数据库返回值某字段是 List 该怎么搞?,第1张

解决方法:如果确认是单条数据,可以直接 Object? ***(**)。没有封装成对象时,默认返回的是List<Map<字段名称String,列值Object>>这样的数据。Dao接口:

List<Map<String,Object>>list(Integer id)

SQL:

<select id="list" parameterType="Integer" resultType="Map">。

拓展:

1、MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。iBATIS一词来源于"internet"和"abatis"的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(sDAO)。

2、MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

<select id="DAO接口方法名称" parameterType="参数类型" resultType="返回结果类型">

select * from 表 where 。。。

</select>

resultType 可以是任意Object对象,如果多条数据,这这个方法返回的是List<Object?>,

如果确认是单条数据,可以直接 Object? ***(**)。

没有封装成对象时,默认返回的是List<Map<字段名称String,列值Object>>这样的数据。

Dao接口:

List<Map<String,Object>>list(Integer id)

SQL:

<select id="list" parameterType="Integer" resultType="Map">

select * from aaa

<where>

<if test="null!=id">

id >#{id}

</if>

</where>

</select>

以上示例中表示查询id>某个数值的所有结果,返回类型为MAP

执行脚本后没有返回结果的吧,看ScriptRunner源码,没有提供任何返回结果的。

private void executeStatement(String command) throws SQLException, UnsupportedEncodingException {

boolean hasResults = false

Statement statement = connection.createStatement()

statement.setEscapeProcessing(escapeProcessing)

String sql = command

if (removeCRs)

sql = sql.replaceAll("\r\n", "\n")

if (stopOnError) {

hasResults = statement.execute(sql)

} else {

try {

hasResults = statement.execute(sql)

} catch (SQLException e) {

String message = "Error executing: " + command + ". Cause: " + e

printlnError(message)

}

}

printResults(statement, hasResults)

try {

statement.close()

} catch (Exception e) {

// Ignore to workaround a bug in some connection pools

}

}

...

有结果时,最后调用了这个方法打印出来而已。

private void print(Object o) {

if (logWriter != null) {

logWriter.print(o)

logWriter.flush()

}

}

你可以调用

public void setLogWriter(PrintWriter logWriter) {

this.logWriter = logWriter

}

传入你自己的Writer。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9950589.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存