<?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%2FDatabase_SQL_JDBC%2FPredicate</id>
		<title>Java/Database SQL JDBC/Predicate - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FDatabase_SQL_JDBC%2FPredicate"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Database_SQL_JDBC/Predicate&amp;action=history"/>
		<updated>2026-04-06T13:24:08Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java/Database_SQL_JDBC/Predicate&amp;diff=6883&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Database_SQL_JDBC/Predicate&amp;diff=6883&amp;oldid=prev"/>
				<updated>2010-06-01T06:33:28Z</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:33, 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/Database_SQL_JDBC/Predicate&amp;diff=6882&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java/Database_SQL_JDBC/Predicate&amp;diff=6882&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:44Z</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;== Predicate implementation ==&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;
JDBC Recipes: A Problem-Solution Approach (Problem-Solution Approach) (Hardcover)&lt;br /&gt;
by Mahmoud Parsian &lt;br /&gt;
&lt;br /&gt;
# Publisher: Apress (September 15, 2005)&lt;br /&gt;
# Language: English&lt;br /&gt;
# ISBN: 1590595203&lt;br /&gt;
*/&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
import javax.sql.RowSet;&lt;br /&gt;
import javax.sql.rowset.FilteredRowSet;&lt;br /&gt;
import javax.sql.rowset.Predicate;&lt;br /&gt;
import com.sun.rowset.FilteredRowSetImpl;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar, age int);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name,age ) values (1,&amp;quot;nameValue&amp;quot;, 10)&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name,age ) values (2,&amp;quot;anotherValue&amp;quot;, 100)&amp;quot;);&lt;br /&gt;
    FilteredRowSet frs = new FilteredRowSetImpl();&lt;br /&gt;
    frs.setUsername(&amp;quot;sa&amp;quot;);&lt;br /&gt;
    frs.setPassword(&amp;quot;&amp;quot;);&lt;br /&gt;
    frs.setUrl(&amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;);&lt;br /&gt;
    frs.setCommand(&amp;quot;SELECT id, name, age FROM survey&amp;quot;);&lt;br /&gt;
    frs.execute();&lt;br /&gt;
    System.out.println(&amp;quot;--- Unfiltered RowSet: ---&amp;quot;);&lt;br /&gt;
    while (frs.next()) {&lt;br /&gt;
      System.out.println(frs.getRow() + &amp;quot; - &amp;quot; + frs.getString(&amp;quot;id&amp;quot;) + &amp;quot;:&amp;quot; + frs.getString(&amp;quot;name&amp;quot;)&lt;br /&gt;
          + &amp;quot;:&amp;quot; + frs.getInt(&amp;quot;age&amp;quot;));&lt;br /&gt;
    }&lt;br /&gt;
    // create a filter that restricts entries in&lt;br /&gt;
    // the age column to be between 7 and 10&lt;br /&gt;
    AgeFilter filter = new AgeFilter(7, 10, 3);&lt;br /&gt;
    // set the filter.&lt;br /&gt;
    frs.beforeFirst();&lt;br /&gt;
    frs.setFilter(filter);&lt;br /&gt;
    // go to the beginning of the Rowset&lt;br /&gt;
    System.out.println(&amp;quot;--- Filtered RowSet: ---&amp;quot;);&lt;br /&gt;
    // show filtered data&lt;br /&gt;
    while (frs.next()) {&lt;br /&gt;
      System.out.println(frs.getRow() + &amp;quot; - &amp;quot; + frs.getString(&amp;quot;id&amp;quot;) + &amp;quot;:&amp;quot; + frs.getString(&amp;quot;name&amp;quot;)&lt;br /&gt;
          + &amp;quot;:&amp;quot; + frs.getInt(&amp;quot;age&amp;quot;));&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println(&amp;quot;--- Try to insert new records ---&amp;quot;);&lt;br /&gt;
    // Try to add an employee with age = 90 (allowed by filter)&lt;br /&gt;
    frs.moveToInsertRow();&lt;br /&gt;
    frs.updateString(1, &amp;quot;999&amp;quot;);&lt;br /&gt;
    frs.updateString(2, &amp;quot;Andre&amp;quot;);&lt;br /&gt;
    frs.updateInt(3, 90);&lt;br /&gt;
    frs.insertRow();&lt;br /&gt;
    frs.moveToCurrentRow();&lt;br /&gt;
    frs.acceptChanges();&lt;br /&gt;
    // try to add an survey with age = 65 (not allowed by filter)&lt;br /&gt;
    frs.moveToInsertRow();&lt;br /&gt;
    frs.updateString(1, &amp;quot;123&amp;quot;);&lt;br /&gt;
    frs.updateString(2, &amp;quot;Jeff&amp;quot;);&lt;br /&gt;
    frs.updateInt(3, 65);&lt;br /&gt;
    frs.insertRow();&lt;br /&gt;
    frs.moveToCurrentRow();&lt;br /&gt;
    frs.acceptChanges();&lt;br /&gt;
    // scroll to first row of rowset&lt;br /&gt;
    frs.beforeFirst();&lt;br /&gt;
    // display rows in FilteredRowset&lt;br /&gt;
    System.out.println(&amp;quot;FilteredRowSet after trying to insert Jeff (age 65) and Andre (age 90):&amp;quot;);&lt;br /&gt;
    while (frs.next()) {&lt;br /&gt;
      System.out.println(frs.getRow() + &amp;quot; - &amp;quot; + frs.getString(&amp;quot;id&amp;quot;) + &amp;quot;:&amp;quot; + frs.getString(&amp;quot;name&amp;quot;)&lt;br /&gt;
          + &amp;quot;:&amp;quot; + frs.getInt(&amp;quot;age&amp;quot;));&lt;br /&gt;
    }&lt;br /&gt;
    frs.close();&lt;br /&gt;
    st.close();&lt;br /&gt;
    frs.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&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;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:databaseName&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;userName&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;password&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
class AgeFilter implements Predicate {&lt;br /&gt;
  private int lowAge;&lt;br /&gt;
  private int highAge;&lt;br /&gt;
  private int columnIndex;&lt;br /&gt;
  private String columnName;&lt;br /&gt;
  public AgeFilter(int lowAge, int highAge, int columnIndex, String columnName) {&lt;br /&gt;
    this.lowAge = lowAge;&lt;br /&gt;
    this.highAge = highAge;&lt;br /&gt;
    this.columnName = columnName;&lt;br /&gt;
    this.columnIndex = columnIndex;&lt;br /&gt;
  }&lt;br /&gt;
  public AgeFilter(int lowAge, int highAge, int columnIndex) {&lt;br /&gt;
    this(lowAge, highAge, columnIndex, &amp;quot;age&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public boolean evaluate(Object value, String columnName) {&lt;br /&gt;
    boolean evaluation = true;&lt;br /&gt;
    if (columnName.equalsIgnoreCase(this.columnName)) {&lt;br /&gt;
      int columnValue = ((Integer) value).intValue();&lt;br /&gt;
      if ((columnValue &amp;gt;= this.lowAge) &amp;amp;&amp;amp; (columnValue &amp;lt;= this.highAge)) {&lt;br /&gt;
        evaluation = true;&lt;br /&gt;
      } else {&lt;br /&gt;
        evaluation = false;&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    return evaluation;&lt;br /&gt;
  }&lt;br /&gt;
  public boolean evaluate(Object value, int columnNumber) {&lt;br /&gt;
    boolean evaluation = true;&lt;br /&gt;
    if (columnIndex == columnNumber) {&lt;br /&gt;
      int columnValue = ((Integer) value).intValue();&lt;br /&gt;
      if ((columnValue &amp;gt;= this.lowAge) &amp;amp;&amp;amp; (columnValue &amp;lt;= this.highAge)) {&lt;br /&gt;
        evaluation = true;&lt;br /&gt;
      } else {&lt;br /&gt;
        evaluation = false;&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    return evaluation;&lt;br /&gt;
  }&lt;br /&gt;
  public boolean evaluate(RowSet rs) {&lt;br /&gt;
    if (rs == null) {&lt;br /&gt;
      return false;&lt;br /&gt;
    }&lt;br /&gt;
    FilteredRowSet frs = (FilteredRowSet) rs;&lt;br /&gt;
    boolean evaluation = false;&lt;br /&gt;
    try {&lt;br /&gt;
      int columnValue = frs.getInt(this.columnIndex);&lt;br /&gt;
      if ((columnValue &amp;gt;= this.lowAge) &amp;amp;&amp;amp; (columnValue &amp;lt;= this.highAge)) {&lt;br /&gt;
        evaluation = true;&lt;br /&gt;
      }&lt;br /&gt;
    } catch (SQLException e) {&lt;br /&gt;
      return false;&lt;br /&gt;
    }&lt;br /&gt;
    return evaluation;&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>