- 浏览: 377569 次
- 来自: 北京
文章分类
- 全部博客 (237)
- XML (6)
- JavaSE (39)
- Junit (1)
- Maven (10)
- JavaScript (12)
- JavaEE (16)
- HTML5 (10)
- java多线程 (8)
- Hibernate (30)
- Java反射 (3)
- Spring (11)
- Struts (1)
- svn (2)
- linux (12)
- 代码实例 (1)
- 设计模式 (1)
- UML (1)
- javassist (1)
- Oracle (3)
- Hibernate异常 (9)
- DWR (6)
- Java泛型 (2)
- SpringMVC (11)
- Dbunit (3)
- github (2)
- Algorithm (1)
- zTree (1)
- jquery (7)
- freemarker (4)
- mysql (5)
- ffmpeg (1)
- 编码 (1)
- lucene (15)
- hadoop (1)
- JVM (1)
- Regular Expressions (5)
- myeclipse (1)
- 爬虫 (7)
- 加密 (3)
- WebService (2)
- Socket (2)
- Windows (1)
最新评论
-
wxpsjm:
好直接
HV000030: No validator could be found for type: java.lang.Integer. -
wxhhbdx:
学习了,对新手来说很不错的教程。
SpringMVC入门 (二) 数值传递 -
xgcai:
正好在学dwr
DWR入门 (二)用户实例
摘自圣思园 Hibernate25.自定义内存排序器详解及符合主键映射详解
上一节讲到了如何通过设置映射文件属性来实现内存排序,http://alleni123.iteye.com/admin/blogs/1979812
natural->自然排序,升序
unsorted->不排序
此外,我们可以自定义排序规则。方法是定义一个类,让其实现Comparator接口,并且实现该接口中的compare方法,在该方法中实现排序规则即可。
然后将该自定义排序规则的类名作为sort的属性值即可。
配置文件和前几节一样, Student.java, Team.java, Student.hbm.xml,Team.hbm.xml。
首先要创建一个继承Comparator接口的类
这里的排序是首先对两个学生的卡号进行对比,如果卡号不同,则返回对比结果。
但是如果卡号一样,那么就对比名字,返回名字的对比结果。
要使用该Comparator,必须在映射配置文件里配置一下。
查询代码:
这里数据库里面有三行数据,分别是
id_card name
333 alleni
111 eline
222 222
最后的输出结果就是:
eline,222,alleni
也就是会通过对比id_card来进行排序。
============================
异常:
这里插入数据时会报错。
Exception in thread "main" java.lang.ClassCastException: set_compare.Student cannot be cast to java.lang.Comparable
at java.util.TreeMap.put(TreeMap.java:542)
at java.util.TreeSet.add(TreeSet.java:238)
at set_compare.Hibernate_1Insert.main(Hibernate_1Insert.java:38)
貌似要让Student.java类实现Comparable接口才行。 具体以后再研究。
上一节讲到了如何通过设置映射文件属性来实现内存排序,http://alleni123.iteye.com/admin/blogs/1979812
natural->自然排序,升序
unsorted->不排序
此外,我们可以自定义排序规则。方法是定义一个类,让其实现Comparator接口,并且实现该接口中的compare方法,在该方法中实现排序规则即可。
然后将该自定义排序规则的类名作为sort的属性值即可。
配置文件和前几节一样, Student.java, Team.java, Student.hbm.xml,Team.hbm.xml。
首先要创建一个继承Comparator接口的类
public class MyComparator implements Comparator<Student> { @Override public int compare(Student o1, Student o2) { if(o1==o2){ return 0; } int result=o1.getCardId().compareTo(o2.getCardId()); if(result!=0){ return result; } return o1.getName().compareTo(o2.getName()); } }
这里的排序是首先对两个学生的卡号进行对比,如果卡号不同,则返回对比结果。
但是如果卡号一样,那么就对比名字,返回名字的对比结果。
要使用该Comparator,必须在映射配置文件里配置一下。
<hibernate-mapping package="set_compare"> <class name="Team" table="test_team"> <id name="id" column="id" type="string"> <generator class="uuid"> </generator> </id> <property name="name" column="name" type="string" /> <set name="students" table="test_student" sort="set_compare.MyComparator"> <!--这里不能只写MyComparator,否则Hibernate会报错。--> <key column="team_id"></key> <one-to-many class="Student"/> </set> </class> </hibernate-mapping>
查询代码:
Session session=HibernateUtil.openSession(); Team t=(Team) session.get(Team.class, "4028bd81428f34c201428f34c4e90000"); Set s=t.getStudents(); System.out.println(s.size()); System.out.println(t.getName()); Iterator it=s.iterator(); while(it.hasNext()){ System.out.println(((Student)it.next()).getName()); }
这里数据库里面有三行数据,分别是
id_card name
333 alleni
111 eline
222 222
最后的输出结果就是:
eline,222,alleni
也就是会通过对比id_card来进行排序。
============================
异常:
这里插入数据时会报错。
Session session=HibernateUtil.openSession(); Transaction tx=session.beginTransaction(); Team team=new Team(); team.setName("english"); team.setStudents(new TreeSet()); Set set=team.getStudents(); Student s1=new Student(null,"111","alleni",23,team); Student s2=new Student(null,"222","eline",23,team); Student s3=new Student(null,"333","3333",23,team); set.add(s1); set.add(s2); set.add(s3); session.save(team); tx.commit();
Exception in thread "main" java.lang.ClassCastException: set_compare.Student cannot be cast to java.lang.Comparable
at java.util.TreeMap.put(TreeMap.java:542)
at java.util.TreeSet.add(TreeSet.java:238)
at set_compare.Hibernate_1Insert.main(Hibernate_1Insert.java:38)
貌似要让Student.java类实现Comparable接口才行。 具体以后再研究。
发表评论
-
Connection is read-only. Queries leading to data modification are not allowed。
2014-04-06 21:52 3735<tx:advice id="txAdvic ... -
org.hibernate.HibernateException: No Session found for current thread
2014-04-06 12:37 0今天在maven中整合spring和hibernate,并使用 ... -
select new Topic from ' Mysql 生成SQL语句错误
2014-03-30 22:51 1661Caused by: com.mysql.jdbc.exce ... -
Unable to locate appropriate constructor on class
2014-02-20 00:11 1467org.hibernate.hql.internal.ast. ... -
Hibernate的load和get实际应用区分简单实例
2013-12-18 11:58 876今天在看孔浩的CMS视频时候看到的。 在57 -文章管理06 ... -
自定义OpenSessionInViewer过滤器
2013-12-11 12:12 1058摘自孔浩视频 spring部分-17_spring_SSH整合 ... -
数据库事务 (三)虚读(Phantom Read)
2013-12-01 13:21 0关于各种读 虚读 phantom read: 转自维基 ... -
Hibernate悲观锁
2013-11-30 17:30 0为了防止两个线程同时修改一个数据,造成更新数据丢失,我们可以使 ... -
Hibernate查询HQL实例
2013-11-29 15:56 1295三个实体类对象: public class Team { ... -
QBC与HQL检索
2013-11-28 17:39 0QBC(Query By Criteria) API提供了检索 ... -
Hibernate继承映射
2013-11-28 12:36 653继承映射分为三种情况 1.每个子类一张表 比如说有一个Pers ... -
Hibernate通过Composite-element配置外联表实例 (码)
2013-11-28 11:07 1022摘自圣思园Hibenrate 26. 组件映射深度解析 -37 ... -
Hibernate配置复合主键 composite primary key (二)
2013-11-27 16:41 1450摘自圣思园Hibernate 26.组件映射深度解析 上一篇 ... -
Hibernate配置复合主键 composite primary key (一)
2013-11-27 14:15 2456这篇是关于如何配置Hibernate实现复合主键的映射功能。 ... -
Hibernate配置Set和List
2013-11-25 10:44 1884========================Set==== ... -
Hibernate的Map配置
2013-11-23 16:21 1300摘自圣思园022.Hibernate映 ... -
Hibernate多对多配置
2013-11-21 22:39 884场景: Student和Course,每一个Student有多 ... -
Hibernate延迟加载案例 (多: 一: 一,附代码)
2013-11-21 17:41 594摘自圣思园Hibernate20.一 ... -
Hibernate一对一配置
2013-11-20 21:49 1049摘自圣思园 19.Hibernate的对象检索策略深度解析.a ... -
Hibernate的对象检索策略 (一) SQL左外连接检索策略
2013-11-20 15:32 1141首先是测试表的结构: 先通过hibernate将数据放入 ...
相关推荐
在Hibernate中,可以通过实现`Comparator`接口并覆盖`compare()`方法来自定义比较逻辑,然后在查询时传递这个比较器。例如: ```java public class GbkOrderComparator implements Comparator<String> { @Override ...
为了自定义排序规则,你需要创建一个实现了`Comparator`接口的类,例如`FlowInfoComparator`,并在其中重写`compare()`方法,根据需要比较的字段进行排序。然后在Hibernate的映射文件中,为`<set>`标签添加`sort`...
Comparator接口用于自定义比较规则,Comparable接口实现对象的自然排序。 再者,Java的IO流系统是处理输入输出的关键。字节流按字节读写,例如FileInputStream和FileOutputStream,操作文件时必须注意关闭流,防止...
在IT行业中,数据库操作是应用开发的核心部分,而IBatis和Hibernate作为两个流行的ORM(对象关系映射)框架,极大地...通过创建自定义的工具类,我们可以更好地管理和操作查询结果,同时利用延迟加载等策略来优化性能。
如果需要自定义排序规则,可以实现`Comparable`接口或使用`Comparator`。 11. **Hibernate的XML配置**: Hibernate配置包括主配置文件`hibernate.cfg.xml`,定义数据源、JDBC连接参数等。实体映射文件(如`XXX.hbm...
- 自定义比较器:通过实现`Comparator`接口,可以自定义排序规则。 3. **分页处理**: - 分页查询通常涉及到数据库操作,可以使用JDBC的`Statement`或`PreparedStatement`进行分页查询,或者使用ORM框架如...
2. **Comparator接口**:用于自定义对象的排序规则。 **详细解析:** 在Java中,为了方便对自定义对象进行排序,可以使用`Comparable`接口或`Comparator`接口。这里以`Comparator`为例进行说明。 假设有一个`...
迭代器(Iterator)用于遍历集合,而equals和hashCode方法用于对象比较,Comparable和Comparator接口则用于自定义排序规则。 反射机制允许程序在运行时动态地获取类的信息并调用其方法。Class类、Method类、Field类是...
如果集合中的对象没有自然顺序,那么需要实现`Comparable`接口或者在映射中指定`comparator`属性来指定排序规则。 如果在`Employee`类中,我们希望证书按照某种顺序(比如证书名称的字母顺序)存储,我们可以将`...
- 如果ArrayList中存储的是Person对象,可以通过Collections.sort()方法结合Comparator接口,自定义比较规则按年龄排序。 4. **HashMap的键值要求** - HashMap的键必须是不可变的,且必须实现hashCode()和equals...
- `comparator`: 用于对树节点进行排序的比较器,实现java.util.Comparator接口。 - `sortProperty`: 排序属性名称,默认按照节点名称排序,如果需要使用其他属性排序,可以设置此值。 - `reverse`: 是否反向排序,...
Java类的排序:实现Comparable或Comparator接口可使Java类对象进行排序。 Thread类的sleep()与Object类的wait()的区别:sleep()是Thread的静态方法,不会释放锁,而wait()是Object的方法,调用后会释放对象的锁。 ...
在Java中,我们可以通过构建自定义的类来实现类似DataSet的功能,比如包含多个DataTable(在Java中可能称为Table或Record),每个DataTable则由多个DataRow(Record)组成,这些DataRow包含了列名和对应的值。...
3. 排序与比较:掌握Collections.sort()方法,以及Comparable和Comparator接口的应用。 三、多线程 1. 线程创建:通过Thread类和Runnable接口创建线程。 2. 线程同步:理解synchronized关键字,wait()、notify()和...
同时,对数据进行排序(如按价格升序或降序排列)则需要使用到排序算法,如快速排序、归并排序等。 4. **多线程**:为了提高效率,价格抓取可能会实现多线程或者异步处理。Java提供了丰富的并发控制机制,如`...
尽管Hibernate默认不保证Map的排序,但你可以通过自定义Comparator或使用自然排序来实现。配置方式与普通Map相似,只是在Java代码中需要使用SortedMap子类,并确保在映射文件中指定排序规则。 ```java private ...
3. **集合框架**:ArrayList、LinkedList、HashSet、HashMap等容器的使用及其原理,以及泛型、迭代器、Comparable与Comparator接口的应用。 4. **多线程**:线程的创建方式(Thread类和Runnable接口),同步机制...
- **comparator**: 排序器,用于对树节点进行排序。节点类型为`net.jcreate.e3.tree.support.WebTreeNode`。 - **sortProperty**: 排序属性名称,默认按节点名称排序。如果业务对象具有排序属性,则需指定该属性名,...
- **TreeSet**基于红黑树实现,自然排序或根据提供的Comparator排序,时间复杂度为O(log n)。 #### 15. JavaScript与Java的区别 - **JavaScript**是一种运行在浏览器上的脚本语言,主要用于网页交互。 - **Java**...
- `sort(Comparator<Row> comparator)`: 对行进行排序。 - `aggregate(AggregateFunction, T> function)`: 应用聚合函数,如求和、平均值等。 5. **文件操作**: 提供读写数据到文件的功能,可以使用XML序列化...