[z]nativeSql
http://blog.csdn.net/chenallen1025/article/details/9169543
EntityManager API 提供了创建 Query 实例以执行原生 SQL 语句的createNativeQuery方法。
实体User:
- package com.cndatacom.jpa.entity;
- import javax.persistence.Column;
- import javax.persistence.Entity;
- import javax.persistence.GeneratedValue;
- import javax.persistence.Id;
- import javax.persistence.Table;
- @Entity
- @Table(name="t_user")
- public class User {
- /**
- * 主键
- */
- @Id
- @GeneratedValue
- private Long id;
- /**
- * 名字
- */
- @Column(name="name",length=50)
- private String name;
- /**
- * 密码
- */
- @Column(name="password",length=20)
- private String password;
- /**
- * 邮箱
- */
- @Column(name="email",length=50)
- private String email;
- /**
- * 年龄
- */
- @Column(name="age",length=3)
- private int age;
- public User() {
- }
- //以下省略getter/setter方法
- //......
- }
测试:
- package com.cndatacom.jpa.test;
- import java.util.List;
- import javax.persistence.EntityManager;
- import javax.persistence.EntityManagerFactory;
- import javax.persistence.Persistence;
- import javax.persistence.Query;
- import org.junit.After;
- import org.junit.Before;
- import org.junit.Test;
- import com.cndatacom.jpa.entity.User;
- /**
- * 测试JPA原生SQL查询
- * @author Luxh
- */
- public class TestNativeQuery {
- EntityManagerFactory emf = null;
- @Before
- public void before() {
- //根据在persistence.xml中配置的persistence-unit name 创建EntityManagerFactory
- emf = Persistence.createEntityManagerFactory("myJPA");
- }
- @After
- public void after() {
- //关闭EntityManagerFactory
- if(null != emf) {
- emf.close();
- }
- }
- /**
- * 查询的结果是对象数组的集合
- */
- @Test
- public void testNativeQuery1() {
- EntityManager em = emf.createEntityManager();
- //定义SQL
- String sql = "SELECT * FROM t_user";
- //创建原生SQL查询QUERY实例
- <span style="color:#ff0000;">Query query = em.createNativeQuery(sql);</span>
- //执行查询,返回的是对象数组(Object[])列表,
- //每一个对象数组存的是相应的实体属性
- List objecArraytList = query.getResultList();
- for(int i=0;i<objecArraytList.size();i++) {
- Object[] obj = (Object[]) objecArraytList.get(i);
- //使用obj[0],obj[1],obj[2]...取出属性
- }
- em.close();
- }
- /**
- * 查询的结果是实体的集合
- */
- @Test
- public void testNativeQuery2() {
- EntityManager em = emf.createEntityManager();
- //定义SQL
- String sql = "SELECT * FROM t_user";
- //创建原生SQL查询QUERY实例,指定了返回的实体类型
- <span style="color:#ff0000;"> Query query = em.createNativeQuery(sql,User.class);
- </span> //执行查询,返回的是实体列表,
- List<User> userList = query.getResultList();
- em.close();
- }
- /**
- * 查询单个属性
- * 返回的是这个属性值的集合
- */
- @Test
- public void testNativeQuery3() {
- EntityManager em = emf.createEntityManager();
- //定义SQL
- String sql = "SELECT t.name FROM t_user t";
- //创建原生SQL查询QUERY实例
- <span style="color:#ff0000;"> Query query = em.createNativeQuery(sql);</span>
- //执行查询,返回的是String类型的集合,因为name这个属性是String类型
- List<String> resultList = query.getResultList();
- em.close();
- }
- /**
- * 查询多个属性
- * 返回的是这些属性值的数组的集合
- */
- @Test
- public void testNativeQuery4() {
- EntityManager em = emf.createEntityManager();
- //定义SQL
- String sql = "SELECT t.name,t.age,t.email FROM t_user t";
- //创建原生SQL查询QUERY实例
- <span style="color:#ff0000;"> Query query = em.createNativeQuery(sql); </span>
- //执行查询,返回的是查询属性值数组的集合
- List objecArraytList = query.getResultList();
- for(int i=0;i<objecArraytList.size();i++) {
- Object[] obj = (Object[]) objecArraytList.get(i);
- //使用obj[0],obj[1],obj[2]取出属性
- }
- em.close();
- }
- }
[z]nativeSql的更多相关文章
- 【Python】使用torrentParser1.03对多文件torrent的分析结果
Your environment has been set up for using Node.js 8.5.0 (x64) and npm. C:\Users\horn1>cd C:\User ...
- Android立体旋转动画实现与封装(支持以X、Y、Z三个轴为轴心旋转)
本文主要介绍Android立体旋转动画,或者3D旋转,下图是我自己实现的一个界面 立体旋转分为以下三种: 1. 以X轴为轴心旋转 2. 以Y轴为轴心旋转 3. 以Z轴为轴心旋转--这种等价于andro ...
- Z字形扫描(201412-2)
问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z字形扫描的过程如下图所示: 对于下面的4×4的矩阵, 1 5 3 9 3 7 5 ...
- 【IOS】将一组包含中文的数据按照#ABC...Z✿分组
上一篇文章[IOS]模仿windowsphone列表索引控件YFMetroListBox里面 我们一步步的实现了WindowsPhone风格的索引. 但是有没有发现,如果你要实现按照字母排序,你还得自 ...
- Java 压缩/ 解压 .Z 文件
1.问题描述 公司项目有需要用 JAVA 解压 .z文件. .z 是 unix 系统常见的压缩文件. 2.源码 import com.chilkatsoft.CkUnixCompress; impor ...
- 中文编程语言Z语言开源正式开源!!!
(Z语言基于.NET环境,源码中有很多高技术的代码,让更多的人知道对大家有会有很好的帮助,请管理员一点要批准放在首页) 本人实现的中文编程语言Z语言现在正式开源,采用LGPL协议. 编译器核心的网址为 ...
- CCF——Z字形扫描问题
试题编号: 201412-2 试题名称: Z字形扫描 时间限制: 2.0s 内存限制: 256.0MB 问题描述: 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag ...
- Z.ExtensionMethods 一个强大的开源扩展库
今天有意的在博客园里面搜索了一下 Z.ExtensionMethods 这个扩展类库,确发现只搜到跟这个真正相关的才两篇博文而已,我都点进去看了一下,也都只是提到而已,没有专门介绍,才引起我写这篇文档 ...
- Linux Ctrl+c与ctrl+z的区别
提问:CTRL-Z和CTRL-C区别?回答:CTRL-Z和CTRL-C都是中断命令,但是他们的作用却不一样.CTRL-C是强制中断程序的执行,而CTRL-Z的是将任务中断,但是此任务并没有结束,他仍然 ...
随机推荐
- 【387】Python format 格式化函数
参考:Python format 格式化函数 # 保留小数点后两位 f'{3.1415926:.2f}' # 带符号保留小数点后两位 f'{3.1415926:+.2f}' f'{-1:+.2f}' ...
- python玩丢手绢问题,出局的顺序
# 丢手绢问题# 游戏规则: 有N个小朋友玩丢手绢游戏,做成一圈,从第一个小朋友开始数数,从一开始数,数到指定数字的小朋友要出列,然后下一个小朋友继续从1开始数,依次类推,算出最后一个留下来的小朋友是 ...
- ArcGIS案例学习笔记_3_2_CAD数据导入建库
ArcGIS案例学习笔记_3_2_CAD数据导入建库 计划时间:第3天下午 内容:CAD数据导入,建库和管理 目的:生成地块多边形,连接属性,管理 问题:CAD存在拓扑错误,标注位置偏移 教程:pdf ...
- svg-edit和svg中的自定义属性
用svg的码农们肯定知道,在path.rect等元数据中会加入一些自定义属性,保存于数据库,但是用svg-edit编辑器时, 读取的时候,无法读取些这些自定义属性.解决办法:找sanitize.js文 ...
- 吴裕雄 06-MySQL选择数据库
实例以下实例选取了数据库 RUNOOB:use RUNOOB;注意:所有的数据库名,表名,表字段都是区分大小写的.所以你在使用SQL命令时需要输入正确的名称. 使用PHP脚本选择MySQL数据库PHP ...
- Applese涂颜色-欧拉降幂公式
链接:https://ac.nowcoder.com/acm/contest/330/E来源:牛客网 题目描述 精通程序设计的 Applese 叕写了一个游戏. 在这个游戏中,有一个 n 行 m 列的 ...
- 附加任务:团队作业7 Alpha冲刺
附加任务:团队作业7 Alpha冲刺 附加任务要求参考东北师范大学陈志勇老师博客:https://edu.cnblogs.com/campus/nenu/2016SE_NENU/homework/19 ...
- spring boot 代理(not eligible for auto-proxying)
spring 事务机制网上的案例很多,关于事务 不能回滚也有很多的类型,不同的问题有不同的处理方案,本篇博客主要介绍两种事务不能回滚的问题解决方案: 问题一: 在同一个对象中有两个方法,分别未方 ...
- SQL Server - 使用 Merge 语句实现表数据之间的对比同步
表数据之间的同步有很多种实现方式,比如删除然后重新 INSERT,或者写一些其它的分支条件判断再加以 INSERT 或者 UPDATE 等.包括在 SSIS Package 中也可以通过 Lookup ...
- express 中间件
[express 中间件] 中间件(Middleware) 是一个函数,它可以访问请求对象(request object (req)), 响应对象(response object (res)), 和 ...