在spring与hibernate整合时进行数据库检索,执行原生sql:

  

public AppointmentEvaluateVo searchMyfeedbackDetail(String accountId, String fbId) {

        String sql = "select ae.id as fbId ,ae.app_id as appId, a.app_no as appNo,"
+ " si.service_item AS serItem,a.app_service_time as feedTime,ae.remark as"
+ " feedCon, cou.attitudeScore AS attitudeScore,cou.qualityScore AS qualityScore,"
+ "cou.prescriptionScore AS prescriptionScore from appointment_evaluate ae LEFT JOIN"
+ " appointment a ON ae.app_id=a.id LEFT JOIN organization_service_item osi "
+ "ON a.item_id=osi.id LEFT JOIN service_item si ON osi.service_item_id=si.id "
+ "LEFT JOIN ( SELECT _a.item_id, count(_a.id) AS orderNum, _ae.attitude as "
+ "attitudeScore, _ae.quality as qualityScore, _ae.prescription as prescriptionScore "
+ " FROM appointment _a RIGHT JOIN appointment_evaluate _ae ON `_a`.id = `_ae`.app_id "
+ " GROUP BY _a.item_id) cou ON osi.id = cou.item_id where 1=1 and ae.creator='" + accountId
+ "' and ae.id='" + fbId + "';"; List rows = jdbcTemplate.queryForList(sql);
AppointmentEvaluateVo av = new AppointmentEvaluateVo();
Iterator ite = rows.iterator();
while (ite.hasNext()) {
Map avMap = (Map) ite.next();
av.setFbId(avMap.get("fbId").toString());
av.setAppId(avMap.get("appId").toString());
av.setAppNo(avMap.get("appNo").toString());
av.setSerItem(avMap.get("serItem").toString());
av.setFeedTime(avMap.get("feedTime").toString());
av.setFeedCon(avMap.get("feedCon").toString());
av.setTotScore(avMap.get("prescriptionScore").toString());
av.setTquaScore(avMap.get("qulityScore").toString());
av.setSerScore(avMap.get("attitudeScore").toString());
}
return av;
}

  第二种:

  

public Student findStudentById(int id){
String sql = "select * from tb_student where id=?";
final Student student = new Student();
jdbcTemplate.query(sql,new Object[]{id},new RowCallbackHandler(){
public void processRow(ReultSet resultSet) throws SQLException{
student.setId(resultSet.getInt("id"));
student.setName(resultSet.getString("name"));
}
});
return student;
}

  

增删改查简单示例:

package com.demo.manager;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.UUID; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.stereotype.Repository;
import org.springframework.util.StringUtils; import com.demo.pojo.Account; @Repository
public class AccountManager {
@Autowired
private JdbcTemplate jdbcTemplate; /**
* 添加
*
* @param ac
*/
public void addAccount(Account account) { jdbcTemplate.update("insert into tb_account(id,name,address,age) values (?,?,?,?)",
new Object[] { StringUtils.hasText(account.getId()) ? account.getId() : UUID.randomUUID(),
StringUtils.hasText(account.getName()) ? account.getName() : "",
StringUtils.hasText(account.getAddress()) ? account.getAddress() : "", account.getAge() });
} /**
* 根据id获取账户信息
* @param a
* @return
*/
public Account getAccount(Account a) {
Account account = jdbcTemplate.queryForObject("select * from tb_account where id=?", new Object[] { a.getId() },
new BeanPropertyRowMapper<>(Account.class));
return account;
} public List<Account> getAll() {
List<Account> accounts = jdbcTemplate.query("select * from tb_account",new RowMapper<Account>() { @Override
public Account mapRow(ResultSet rs, int num) throws SQLException { Account account = new Account();
account.setId(rs.getString(1));
account.setName(rs.getString(2));
account.setAddress(rs.getString(3));
account.setAge(rs.getInt(4));
return account;
}
});
return accounts;
} /**
* 删除
*
* @param ac
*/
public void deleteAccount(Account account) { jdbcTemplate.update("delete from tb_account where id=?",
new Object[] { account.getId() });
} /**
* 更新
*
* @param ac
*/
public void updateAccount(Account account) { jdbcTemplate.update("update tb_account set name=?,address=? where id=?",
new Object[] { account.getName(),account.getAddress(),account.getId() });
}
}

Spring的jdbcTemplate查询执行原生sql的更多相关文章

  1. orm分组,聚合查询,执行原生sql语句

    from django.db.models import Avg from app01 import models annotate:(聚合查询) ret=models.Article.objects ...

  2. 10、Entity Framework Core 3.1入门教程-执行原生SQL

    本文章是根据 微软MVP solenovex(杨旭)老师的视频教程编写而来,再加上自己的一些理解. 视频教程地址:https://www.bilibili.com/video/BV1xa4y1v7rR ...

  3. Spring 中jdbcTemplate 实现执行多条sql语句

    说一下Spring框架中使用jdbcTemplate实现多条sql语句的执行: 很多情况下我们需要处理一件事情的时候需要对多个表执行多个sql语句,比如淘宝下单时,我们确认付款时要对自己银行账户的表里 ...

  4. Django中的ORM相关操作:F查询,Q查询,事物,ORM执行原生SQL

    一    F查询与Q查询: 1 . F查询: 在上面所有的例子中,我们构造的过滤器都只是将字段值与某个常量做比较.如果我们要对两个字段的值做比较,那该怎么做呢? Django 提供 F() 来做这样的 ...

  5. python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

    12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefaul ...

  6. java:Hibernate框架3(使用Myeclipse逆向工程生成实体和配置信息,hql语句各种查询(使用hibernate执行原生SQL语句,占位符和命名参数,封装Vo查询多个属性,聚合函数,链接查询,命名查询),Criteria)

    1.使用Myeclipse逆向工程生成实体和配置信息: 步骤1:配置MyEclipse Database Explorer: 步骤2:为项目添加hibernate的依赖: 此处打开后,点击next进入 ...

  7. Django的F查询和Q查询,事务,ORM执行原生SQL

    F查询和Q查询,事务及其他   F查询和Q查询 F查询 在上面所有的例子中,我们构造的过滤器都只是将字段值与某个我们自己设定的常量做比较.如果我们要对两个字段的值做比较,那该怎么做呢? Django ...

  8. Hibernate执行原生SQL返回List<Map>类型结果集

    我是学java出身的,web是我主要一块: 在做项目的时候最让人别扭的就是hibernate查询大都是查询出List<T>(T指代对应实体类)类型 如果这时候我用的联合查询,那么返回都就是 ...

  9. django系列5.4--ORM中执行原生SQL语句, Python脚本中调用django环境

    ORM执行原生sql语句 在模型查询API不够用的情况下,我们还可以使用原始的SQL语句进行查询. Django 提供两种方法使用原始SQL进行查询:一种是使用raw()方法,进行原始SQL查询并返回 ...

随机推荐

  1. MarkdownPad2 Pro v2.4.2.29969 专业中文破解版完美支持table表格语法

    在网上搞了半天,终于搞定了支持table简写语法的markdown软件. 下载地址:http://download.csdn.net/detail/wang_jun_hua/8180717 下载包内含 ...

  2. C#软件设计——小话设计模式原则之:开闭原则OCP

    前言:这篇继续来看看开闭原则.废话少说,直接入正题. 软件设计原则系列文章索引 C#软件设计——小话设计模式原则之:依赖倒置原则DIP C#软件设计——小话设计模式原则之:单一职责原则SRP C#软件 ...

  3. 【Python】[面向对象编程] 类和实例

    1.注:必须牢记类是抽象的模板,而实例是根据类创建出来的一个个具体的“对象”2.定义类通过class 关键字:class 后面跟着类名,类名通常都是大写开头,接着是(object),表示类是从哪里继承 ...

  4. Uninstall from GAC In C# code

    How do I uninstall the GAC from my C# application. I am not able to uninstall, the particular exe an ...

  5. maven-各配置文件详解

    1.setting.xml http://www.cnblogs.com/yangxia-test/p/4409736.html <?xml version="1.0" en ...

  6. Jstat PID not found

    解决步骤 删除/tmp/hsperfdata_{USER}文件夹,如果是root用户登录,即为/tmp/hsperfdata_root 通过chown.chmod命令保证执行jstat用户必定拥有对/ ...

  7. 怪物AI之发现玩家(视觉范围发现系列)

    在网上找到一些资料参考,然后写写自己的想法. 这里感谢MOMO等大神. 我们用玩家检测怪物的方法来测,这样比较试用与弱联网游戏,每次在同步玩家的时候来判断玩家与怪物的位置. 这里给出两个处理方式: 1 ...

  8. Github上fork了别人的项目之后如何同步代码

    其实很简单,如下: fork了别人代码到自己仓库,然后把自己仓库的代码clone下来 在本地添加远程仓库添加fork的代码库,git remote add xxx url git pull xxx m ...

  9. 【Beta】第五次任务发布

    PM #100 日常管理&dev版宣传&设计报告管理后台. 后端 #101 完成收藏功能 完成管理员权限表的生成和接入(按位压缩权限表) 验收条件:收藏功能能够正常使用.能够区分常规用 ...

  10. jQuery下拉菜单插件Tendina.

    插件效果: 下载地址和文档: https://github.com/iprignano/tendina