<?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_Column_Formula</id>
		<title>Java/Hibernate/Hibernate Column Formula - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FHibernate%2FHibernate_Column_Formula"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Column_Formula&amp;action=history"/>
		<updated>2026-04-04T03:32:11Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Column_Formula&amp;diff=7839&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Hibernate/Hibernate_Column_Formula&amp;diff=7839&amp;oldid=prev"/>
				<updated>2010-06-01T06:51:03Z</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_Column_Formula&amp;diff=7838&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_Column_Formula&amp;diff=7838&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;== Column Formula: String Concatenate ==&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;
&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 PUBLIC &amp;quot;-//Hibernate/Hibernate Mapping DTD//EN&amp;quot; &lt;br /&gt;
&amp;quot;http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-mapping&amp;gt;&lt;br /&gt;
    &amp;lt;class  name=&amp;quot;Account&amp;quot; table=&amp;quot;account&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&amp;quot; type=&amp;quot;string&amp;quot; unsaved-value=&amp;quot;null&amp;quot;&amp;gt; &lt;br /&gt;
            &amp;lt;generator  class=&amp;quot;uuid.hex&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/id&amp;gt;&lt;br /&gt;
        &amp;lt;property   name=&amp;quot;accountnum&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property   name=&amp;quot;firstname&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property   name=&amp;quot;lastname&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property   name=&amp;quot;balance&amp;quot;/&amp;gt; &lt;br /&gt;
        &amp;lt;property   name=&amp;quot;fullname&amp;quot; formula=&amp;quot;concat(firstname, &amp;quot; &amp;quot;, lastname)&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-mapping&amp;gt;&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&lt;br /&gt;
import java.io.*;&lt;br /&gt;
public class Account { &lt;br /&gt;
  private String id; &lt;br /&gt;
  private String accountnum;&lt;br /&gt;
  private double balance;&lt;br /&gt;
  private String firstname;&lt;br /&gt;
  private String lastname;&lt;br /&gt;
  private String fullname;&lt;br /&gt;
  public Account() {&lt;br /&gt;
  }&lt;br /&gt;
&lt;br /&gt;
  public void setId(String s) {&lt;br /&gt;
    id = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setAccountnum(String s) {&lt;br /&gt;
    accountnum = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getAccountnum() {&lt;br /&gt;
    return accountnum;&lt;br /&gt;
  }  &lt;br /&gt;
  public void setBalance(double b) {&lt;br /&gt;
    balance = b;&lt;br /&gt;
  }&lt;br /&gt;
  public double getBalance() {&lt;br /&gt;
    return balance;&lt;br /&gt;
  }&lt;br /&gt;
  public void setFirstname(String s) {&lt;br /&gt;
    firstname = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getFirstname() {&lt;br /&gt;
    return firstname;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLastname(String s) {&lt;br /&gt;
    lastname = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLastname() {&lt;br /&gt;
    return lastname;&lt;br /&gt;
  }&lt;br /&gt;
  public void setFullname(String s) {&lt;br /&gt;
    fullname = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getFullname() {&lt;br /&gt;
    return fullname;&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-configuration PUBLIC&lt;br /&gt;
    &amp;quot;-//Hibernate/Hibernate Configuration DTD//EN&amp;quot;&lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-configuration&amp;gt;&lt;br /&gt;
    &amp;lt;session-factory&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Database connection settings --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.driver_class&amp;quot;&amp;gt;org.hsqldb.jdbcDriver&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.url&amp;quot;&amp;gt;jdbc:hsqldb:data/tutorial&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.username&amp;quot;&amp;gt;sa&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.password&amp;quot;&amp;gt;&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- JDBC connection pool (use the built-in) --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.pool_size&amp;quot;&amp;gt;1&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- SQL dialect --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dialect&amp;quot;&amp;gt;org.hibernate.dialect.HSQLDialect&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Echo all executed SQL to stdout --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;show_sql&amp;quot;&amp;gt;true&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Mapping files --&amp;gt;&lt;br /&gt;
        &amp;lt;mapping resource=&amp;quot;Account.hbm.xml&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/session-factory&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-configuration&amp;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;
      for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        labels[i] = metadata.getColumnLabel(i + 1); // get its label&lt;br /&gt;
        System.out.print(labels[i]+&amp;quot;  &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
      System.out.println(&amp;quot;------------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
        for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        Object value = rs.getObject(i + 1);&lt;br /&gt;
        if(value == null){&lt;br /&gt;
            System.out.print(&amp;quot;       &amp;quot;);&lt;br /&gt;
        }else{&lt;br /&gt;
            System.out.print(value.toString().trim()+&amp;quot;   &amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
      }&lt;br /&gt;
        System.out.println(&amp;quot;       &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.io.Serializable;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
import org.hibernate.*;&lt;br /&gt;
import org.hibernate.cfg.*;&lt;br /&gt;
import org.hibernate.criterion.*;&lt;br /&gt;
import org.hibernate.event.*;&lt;br /&gt;
import org.hibernate.event.def.*;&lt;br /&gt;
public class Main {&lt;br /&gt;
   public static void main(String[] args) throws Exception {&lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table account(id varchar,accountnum varchar,firstname varchar,lastname varchar,balance double);&amp;quot;);    &lt;br /&gt;
&lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
      Account account = new Account();&lt;br /&gt;
      account.setFirstname(&amp;quot;Joe&amp;quot;);&lt;br /&gt;
      account.setLastname(&amp;quot;Smith&amp;quot;);&lt;br /&gt;
      account.setAccountnum(&amp;quot;39084&amp;quot;);&lt;br /&gt;
      account.setBalance(4054.00);&lt;br /&gt;
      session.save(account);&lt;br /&gt;
      session.flush();&lt;br /&gt;
      Account account2 = (Account)session.load(Account.class, account.getId());&lt;br /&gt;
      System.out.println(account2.getFullname());&lt;br /&gt;
      session.flush();&lt;br /&gt;
      session.close();&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from account&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
log4j.rootCategory=WARN, console&lt;br /&gt;
log4j.appender.console=org.apache.log4j.ConsoleAppender&lt;br /&gt;
log4j.appender.console.layout=org.apache.log4j.PatternLayout&lt;br /&gt;
log4j.appender.console.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n&lt;br /&gt;
log4j.appender.stdout.Target=System.out&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>