<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FDatabase_SQL_JDBC%2FCachedRowSet</id>
		<title>Java/Database SQL JDBC/CachedRowSet - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FDatabase_SQL_JDBC%2FCachedRowSet"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/CachedRowSet&amp;action=history"/>
		<updated>2026-04-21T13:12:25Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/CachedRowSet&amp;diff=6927&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/CachedRowSet&amp;diff=6927&amp;oldid=prev"/>
				<updated>2010-06-01T06:34:11Z</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:34, 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://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/CachedRowSet&amp;diff=6926&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/CachedRowSet&amp;diff=6926&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;== Cached RS ==&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;
import java.io.FileInputStream;&lt;br /&gt;
import java.io.FileOutputStream;&lt;br /&gt;
import java.io.ObjectInputStream;&lt;br /&gt;
import java.io.ObjectOutputStream;&lt;br /&gt;
import javax.sql.rowset.CachedRowSet;&lt;br /&gt;
public class CachedRS {&lt;br /&gt;
  private final static String CRS_FILE_LOC = &amp;quot;cachedrs.crs&amp;quot;;&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    FileInputStream fis = new FileInputStream(CRS_FILE_LOC);&lt;br /&gt;
    ObjectInputStream in = new ObjectInputStream(fis);&lt;br /&gt;
    CachedRowSet crs = (CachedRowSet) in.readObject();&lt;br /&gt;
    fis.close();&lt;br /&gt;
    in.close();&lt;br /&gt;
    &lt;br /&gt;
    Class.forName(&amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;);&lt;br /&gt;
    crs.setUrl(&amp;quot;jdbc:oracle:thin:@localhost:1521:ORCL&amp;quot;);&lt;br /&gt;
    crs.setUsername(&amp;quot;yourName&amp;quot;);&lt;br /&gt;
    crs.setPassword(&amp;quot;mypwd&amp;quot;);&lt;br /&gt;
    String sql = &amp;quot;SELECT SSN, Name, Salary, Hiredate FROM Employees WHERE SSN=?&amp;quot;;&lt;br /&gt;
    crs.setCommand(sql);&lt;br /&gt;
    crs.setInt(1, 111111111);&lt;br /&gt;
    crs.execute();&lt;br /&gt;
    FileOutputStream fos = new FileOutputStream(CRS_FILE_LOC);&lt;br /&gt;
    ObjectOutputStream out = new ObjectOutputStream(fos);&lt;br /&gt;
    out.writeObject(crs);&lt;br /&gt;
    out.close();&lt;br /&gt;
    crs.close();&lt;br /&gt;
    &lt;br /&gt;
    fis = new FileInputStream(CRS_FILE_LOC);&lt;br /&gt;
    in = new ObjectInputStream(fis);&lt;br /&gt;
    crs = (CachedRowSet) in.readObject();&lt;br /&gt;
    fis.close();&lt;br /&gt;
    in.close();&lt;br /&gt;
    while (crs.next()) {&lt;br /&gt;
      System.out.print(&amp;quot;SSN: &amp;quot; + crs.getInt(&amp;quot;ssn&amp;quot;));&lt;br /&gt;
      System.out.print(&amp;quot;, Name: &amp;quot; + crs.getString(&amp;quot;name&amp;quot;));&lt;br /&gt;
      System.out.print(&amp;quot;, Salary: $&amp;quot; + crs.getDouble(&amp;quot;salary&amp;quot;));&lt;br /&gt;
      System.out.print(&amp;quot;, HireDate: &amp;quot; + crs.getDate(&amp;quot;hiredate&amp;quot;));&lt;br /&gt;
    }&lt;br /&gt;
    crs.close();&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;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Save CachedRowSet Back To Database ==&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;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
import java.sql.Types;&lt;br /&gt;
import javax.sql.RowSetMetaData;&lt;br /&gt;
import javax.sql.rowset.CachedRowSet;&lt;br /&gt;
import javax.sql.rowset.RowSetMetaDataImpl;&lt;br /&gt;
import com.sun.rowset.CachedRowSetImpl;&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);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (2,&amp;quot;anotherValue&amp;quot;)&amp;quot;);    &lt;br /&gt;
    &lt;br /&gt;
    CachedRowSet crs = null;&lt;br /&gt;
    RowSetMetaData rsMD = new RowSetMetaDataImpl();&lt;br /&gt;
    rsMD.setColumnCount(2);&lt;br /&gt;
    rsMD.setColumnName(1, &amp;quot;id&amp;quot;);&lt;br /&gt;
    rsMD.setColumnType(1, Types.VARCHAR);&lt;br /&gt;
    rsMD.setColumnName(2, &amp;quot;name&amp;quot;);&lt;br /&gt;
    rsMD.setColumnType(2, Types.VARCHAR);&lt;br /&gt;
    // sets the designated column&amp;quot;s table name, if any, to the given String.&lt;br /&gt;
    rsMD.setTableName(1, &amp;quot;survey&amp;quot;);&lt;br /&gt;
    rsMD.setTableName(2, &amp;quot;survey&amp;quot;);&lt;br /&gt;
    // use a custom made RowSetMetaData object for CachedRowSet object&lt;br /&gt;
    crs = new CachedRowSetImpl();&lt;br /&gt;
    crs.setMetaData(rsMD);&lt;br /&gt;
    crs.moveToInsertRow();&lt;br /&gt;
    crs.updateString(1, &amp;quot;1111&amp;quot;);&lt;br /&gt;
    crs.updateString(2, &amp;quot;alex&amp;quot;);&lt;br /&gt;
    crs.insertRow();&lt;br /&gt;
    crs.moveToInsertRow();&lt;br /&gt;
    crs.updateString(1, &amp;quot;2222&amp;quot;);&lt;br /&gt;
    crs.updateString(2, &amp;quot;jane&amp;quot;);&lt;br /&gt;
    crs.insertRow();&lt;br /&gt;
    // if you want to commit changes from a CachedRowSet&lt;br /&gt;
    // object to your desired datasource, then you must&lt;br /&gt;
    // create a Connection object.&lt;br /&gt;
    //&lt;br /&gt;
    //conn = getHSQLConnection();&lt;br /&gt;
    // moves the cursor to the remembered cursor position, usually&lt;br /&gt;
    // the current row. This method has no effect if the cursor is&lt;br /&gt;
    // not on the insert row.&lt;br /&gt;
    crs.moveToCurrentRow();&lt;br /&gt;
    // when the method acceptChanges() is executed, the CachedRowSet&lt;br /&gt;
    // object&amp;quot;s writer, a RowSetWriterImpl object, is called behind the&lt;br /&gt;
    // scenes to write the changes made to the rowset to the underlying&lt;br /&gt;
    // data source. The writer is implemented to make a connection to&lt;br /&gt;
    // the data source and write updates to it.&lt;br /&gt;
    crs.acceptChanges(conn);&lt;br /&gt;
    conn.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:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&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;
           &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>