<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FHibernate%2FHibernate_Filter</id>
		<title>Java/Hibernate/Hibernate Filter - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FHibernate%2FHibernate_Filter"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Filter&amp;action=history"/>
		<updated>2026-04-07T07:27:01Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Filter&amp;diff=7899&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Filter&amp;diff=7899&amp;oldid=prev"/>
				<updated>2010-06-01T06:51:32Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 06:51, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Filter&amp;diff=7898&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Filter&amp;diff=7898&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:45Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Hibernate Filter Demo ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
import java.sql.*;&lt;br /&gt;
import org.hibernate.*;&lt;br /&gt;
import org.hibernate.cfg.*;&lt;br /&gt;
import org.hibernate.criterion.*;&lt;br /&gt;
public class Main {&lt;br /&gt;
  &lt;br /&gt;
  public static void main(String[] args) {&lt;br /&gt;
    HibernateUtil.setup(&amp;quot;create table User ( id int, username VARCHAR, activated boolean);&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
        //insert the users&lt;br /&gt;
        insertUser(&amp;quot;a&amp;quot;,true);&lt;br /&gt;
        insertUser(&amp;quot;b&amp;quot;,true);&lt;br /&gt;
        insertUser(&amp;quot;c&amp;quot;,false);&lt;br /&gt;
        insertUser(&amp;quot;e&amp;quot;,false);&lt;br /&gt;
        insertUser(&amp;quot;e&amp;quot;,false);&lt;br /&gt;
&lt;br /&gt;
        SessionFactory factory = new Configuration().configure().buildSessionFactory();&lt;br /&gt;
        Session session = factory.openSession();&lt;br /&gt;
        Transaction tx = session.beginTransaction();&lt;br /&gt;
        //Show all users&lt;br /&gt;
        System.out.println(&amp;quot;ALL USERS&amp;quot;);&lt;br /&gt;
        displayUsers(session);&lt;br /&gt;
        &lt;br /&gt;
        //Show activated users&lt;br /&gt;
        Filter filter = session.enableFilter(&amp;quot;activatedFilter&amp;quot;);&lt;br /&gt;
        filter.setParameter(&amp;quot;activatedParam&amp;quot;,new Boolean(true));&lt;br /&gt;
        System.out.println(&amp;quot;ACTIVATED USERS&amp;quot;);&lt;br /&gt;
        displayUsers(session);&lt;br /&gt;
        &lt;br /&gt;
        //Show non-activated users&lt;br /&gt;
        filter.setParameter(&amp;quot;activatedParam&amp;quot;,new Boolean(false));&lt;br /&gt;
        System.out.println(&amp;quot;NON-ACTIVATED USERS&amp;quot;);&lt;br /&gt;
        displayUsers(session);&lt;br /&gt;
        &lt;br /&gt;
        session.close();&lt;br /&gt;
    &lt;br /&gt;
&lt;br /&gt;
        HibernateUtil.checkData(&amp;quot;select * from User&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
    public static void displayUsers(Session session)&lt;br /&gt;
    {&lt;br /&gt;
        Transaction trans = session.beginTransaction();&lt;br /&gt;
        Query query = session.createQuery(&amp;quot;from User&amp;quot;);&lt;br /&gt;
        Iterator results = query.iterate();&lt;br /&gt;
        while (results.hasNext())&lt;br /&gt;
        {&lt;br /&gt;
            User user = (User) results.next();&lt;br /&gt;
            System.out.print(user.getUsername() + &amp;quot; is &amp;quot;);&lt;br /&gt;
            if (user.isActivated())&lt;br /&gt;
            {&lt;br /&gt;
                System.out.println(&amp;quot;activated.&amp;quot;);&lt;br /&gt;
            }&lt;br /&gt;
            else&lt;br /&gt;
            {&lt;br /&gt;
                System.out.println(&amp;quot;not activated.&amp;quot;);&lt;br /&gt;
            }&lt;br /&gt;
        }&lt;br /&gt;
            &lt;br /&gt;
        trans.rumit();&lt;br /&gt;
        &lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
    public static void insertUser(String name, boolean activated)&lt;br /&gt;
    {&lt;br /&gt;
        Session session = HibernateUtil.currentSession();&lt;br /&gt;
        Transaction trans = session.beginTransaction();&lt;br /&gt;
        &lt;br /&gt;
        User user = new User();&lt;br /&gt;
        user.setUsername(name);&lt;br /&gt;
        user.setActivated(activated);        &lt;br /&gt;
        session.save(user);&lt;br /&gt;
        &lt;br /&gt;
        trans.rumit();&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-mapping&lt;br /&gt;
   PUBLIC &amp;quot;-//Hibernate/Hibernate Mapping DTD//EN&amp;quot;&lt;br /&gt;
   &amp;quot;http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-mapping&amp;gt;&lt;br /&gt;
  &amp;lt;class name=&amp;quot;User&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;id name=&amp;quot;id&amp;quot; type=&amp;quot;int&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;generator class=&amp;quot;increment&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/id&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;username&amp;quot; type=&amp;quot;string&amp;quot; length=&amp;quot;32&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;activated&amp;quot; type=&amp;quot;boolean&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;filter name=&amp;quot;activatedFilter&amp;quot; condition=&amp;quot;:activatedParam = activated&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/class&amp;gt;&lt;br /&gt;
  &amp;lt;filter-def name=&amp;quot;activatedFilter&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;filter-param name=&amp;quot;activatedParam&amp;quot; type=&amp;quot;boolean&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/filter-def&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-mapping&amp;gt;&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
public class User&lt;br /&gt;
{&lt;br /&gt;
    private int id;&lt;br /&gt;
    private String username;&lt;br /&gt;
    private boolean activated;&lt;br /&gt;
    &lt;br /&gt;
    &lt;br /&gt;
    public boolean isActivated()&lt;br /&gt;
    {&lt;br /&gt;
        return activated;&lt;br /&gt;
    }&lt;br /&gt;
    public void setActivated(boolean activated)&lt;br /&gt;
    {&lt;br /&gt;
        this.activated = activated;&lt;br /&gt;
    }&lt;br /&gt;
    public int getId()&lt;br /&gt;
    {&lt;br /&gt;
        return id;&lt;br /&gt;
    }&lt;br /&gt;
    public void setId(int id)&lt;br /&gt;
    {&lt;br /&gt;
        this.id = id;&lt;br /&gt;
    }&lt;br /&gt;
    public String getUsername()&lt;br /&gt;
    {&lt;br /&gt;
        return username;&lt;br /&gt;
    }&lt;br /&gt;
    public void setUsername(String username)&lt;br /&gt;
    {&lt;br /&gt;
        this.username = username;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import org.hibernate.HibernateException;&lt;br /&gt;
import org.hibernate.Session;&lt;br /&gt;
import org.hibernate.SessionFactory;&lt;br /&gt;
import org.hibernate.cfg.Configuration;&lt;br /&gt;
public class HibernateUtil {&lt;br /&gt;
    public static final SessionFactory sessionFactory;&lt;br /&gt;
    static {&lt;br /&gt;
        try {&lt;br /&gt;
            // Create the SessionFactory from hibernate.cfg.xml&lt;br /&gt;
            sessionFactory = new Configuration().configure().buildSessionFactory();&lt;br /&gt;
        } catch (Throwable ex) {&lt;br /&gt;
            // Make sure you log the exception, as it might be swallowed&lt;br /&gt;
            System.err.println(&amp;quot;Initial SessionFactory creation failed.&amp;quot; + ex);&lt;br /&gt;
            throw new ExceptionInInitializerError(ex);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    public static final ThreadLocal session = new ThreadLocal();&lt;br /&gt;
    public static Session currentSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        // Open a new Session, if this thread has none yet&lt;br /&gt;
        if (s == null) {&lt;br /&gt;
            s = sessionFactory.openSession();&lt;br /&gt;
            // Store it in the ThreadLocal variable&lt;br /&gt;
            session.set(s);&lt;br /&gt;
        }&lt;br /&gt;
        return s;&lt;br /&gt;
    }&lt;br /&gt;
    public static void closeSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        if (s != null)&lt;br /&gt;
            s.close();&lt;br /&gt;
        session.set(null);&lt;br /&gt;
    }&lt;br /&gt;
    &lt;br /&gt;
    static Connection conn; &lt;br /&gt;
    static Statement st;&lt;br /&gt;
  public static void setup(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      // Step 1: Load the JDBC driver.&lt;br /&gt;
      Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
      // Step 2: Establish the connection to the database.&lt;br /&gt;
      String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
      conn = DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
      st = conn.createStatement();&lt;br /&gt;
      st.executeUpdate(sql);&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      System.err.println(&amp;quot;Got an exception! &amp;quot;);&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
      System.exit(0);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkData(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      HibernateUtil.outputResultSet(st&lt;br /&gt;
          .executeQuery(sql));&lt;br /&gt;
//      conn.close();&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
    public static void outputResultSet(ResultSet rs) throws Exception{&lt;br /&gt;
    ResultSetMetaData metadata = rs.getMetaData();&lt;br /&gt;
    int numcols = metadata.getColumnCount();&lt;br /&gt;
    String[] labels = new String[numcols]; &lt;br /&gt;
    int[] colwidths = new int[numcols];&lt;br /&gt;
    int[] colpos = new int[numcols];&lt;br /&gt;
    int linewidth;&lt;br /&gt;
    linewidth = 1;&lt;br /&gt;
    for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
      colpos[i] = linewidth; &lt;br /&gt;
      labels[i] = metadata.getColumnLabel(i + 1); // get its label&lt;br /&gt;
      int size = metadata.getColumnDisplaySize(i + 1);&lt;br /&gt;
      if (size &amp;gt; 30 || size == -1)&lt;br /&gt;
        size = 30;&lt;br /&gt;
      int labelsize = labels[i].length();&lt;br /&gt;
      if (labelsize &amp;gt; size)&lt;br /&gt;
        size = labelsize;&lt;br /&gt;
      colwidths[i] = size + 1; // save the column the size&lt;br /&gt;
      linewidth += colwidths[i] + 2; // increment total size&lt;br /&gt;
    }&lt;br /&gt;
    StringBuffer divider = new StringBuffer(linewidth);&lt;br /&gt;
    StringBuffer blankline = new StringBuffer(linewidth);&lt;br /&gt;
    for (int i = 0; i &amp;lt; linewidth; i++) {&lt;br /&gt;
      divider.insert(i, &amp;quot;-&amp;quot;);&lt;br /&gt;
      blankline.insert(i, &amp;quot; &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    // Put special marks in the divider line at the column positions&lt;br /&gt;
    for (int i = 0; i &amp;lt; numcols; i++)&lt;br /&gt;
      divider.setCharAt(colpos[i] - 1, &amp;quot;+&amp;quot;);&lt;br /&gt;
    divider.setCharAt(linewidth - 1, &amp;quot;+&amp;quot;);&lt;br /&gt;
    // Begin the table output with a divider line&lt;br /&gt;
    System.out.println(divider);&lt;br /&gt;
    // The next line of the table contains the column labels.&lt;br /&gt;
    // Begin with a blank line, and put the column names and column&lt;br /&gt;
    // divider characters &amp;quot;|&amp;quot; into it. overwrite() is defined below.&lt;br /&gt;
    StringBuffer line = new StringBuffer(blankline.toString());&lt;br /&gt;
    line.setCharAt(0, &amp;quot;|&amp;quot;);&lt;br /&gt;
    for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
      int pos = colpos[i] + 1 + (colwidths[i] - labels[i].length()) / 2;&lt;br /&gt;
      overwrite(line, pos, labels[i]);&lt;br /&gt;
      overwrite(line, colpos[i] + colwidths[i], &amp;quot; |&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println(line);&lt;br /&gt;
    System.out.println(divider);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
      line = new StringBuffer(blankline.toString());&lt;br /&gt;
      line.setCharAt(0, &amp;quot;|&amp;quot;);&lt;br /&gt;
      for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        Object value = rs.getObject(i + 1);&lt;br /&gt;
        overwrite(line, colpos[i] + 1, value.toString().trim());&lt;br /&gt;
        overwrite(line, colpos[i] + colwidths[i], &amp;quot; |&amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println(line);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println(divider);&lt;br /&gt;
      &lt;br /&gt;
    }&lt;br /&gt;
    &lt;br /&gt;
  static void overwrite(StringBuffer b, int pos, String s) {&lt;br /&gt;
    int len = s.length();&lt;br /&gt;
    for (int i = 0; i &amp;lt; len; i++)&lt;br /&gt;
      b.setCharAt(pos + i, s.charAt(i));&lt;br /&gt;
  }&lt;br /&gt;
    &lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>