4752c3741c5730a67244e96e3fad55e65bdb4622
[phpeclipse.git] /
1 package net.sourceforge.phpdt.sql.view.tableview;
2
3 import java.util.Vector;
4
5 import net.sourceforge.phpdt.sql.IConstants;
6 import net.sourceforge.phpdt.sql.adapters.AdapterFactory;
7 import net.sourceforge.phpdt.sql.adapters.DatabaseAdapter;
8 import net.sourceforge.phpdt.sql.adapters.DatabaseInfo;
9 import net.sourceforge.phpdt.sql.adapters.NoSuchAdapterException;
10 import net.sourceforge.phpdt.sql.bookmarks.Bookmark;
11 import net.sourceforge.phpdt.sql.sql.FilterSort;
12 import net.sourceforge.phpdt.sql.sql.MultiSQLServer;
13 import net.sourceforge.phpdt.sql.sql.SQLHelper;
14 import net.sourceforge.phpdt.sql.sql.SQLResults;
15
16 import org.eclipse.swt.SWT;
17 import org.eclipse.swt.widgets.Table;
18 import org.eclipse.swt.widgets.TableColumn;
19 import org.eclipse.swt.widgets.TableItem;
20
21 public class TableAdapter implements IConstants {
22         public static final String DEFAULT = "";
23         public static final String UTF_8 = "UTF-8";
24         public static final String UTF_16 = "UTF-16";
25         
26         private int pageSize = DefaultSizes.PAGE_SIZE;
27         private int maxColumnSize = DefaultSizes.MAX_COLUMN_SIZE;
28         private SQLHelper helper = new SQLHelper();
29         private FilterSort extra = new FilterSort();
30         private int offset = 1;
31         private int totalSize = -1;
32         private Vector rows = new Vector();
33         private Vector columnNames = new Vector();
34         private boolean hasMore = false;
35                 
36         private String table;
37         private String query;
38         
39         private String encoding = "";
40         
41         private TableAdapter() {
42         }
43         public void fullMode() {
44                 offset = 1;
45                 pageSize = Integer.MAX_VALUE;
46         }
47         public void resetMode() {
48                 offset = 1;
49                 pageSize = DefaultSizes.PAGE_SIZE;
50         }
51         public static TableAdapter createFromQuery(SQLResults results) {
52                 TableAdapter retVal = new TableAdapter();
53                 retVal.setQuery(results.getQuery());
54                 retVal.setData(results);
55                 return retVal;
56         }
57         public static TableAdapter createFromTable(String table) {
58                 TableAdapter retVal = new TableAdapter();
59                 retVal.setTable(table);
60                 return retVal;
61         }
62         private void loadSize() {
63                 if (table != null) {
64                         totalSize = helper.getSize(getTableCountQuery());
65                 }
66         }
67         public int getStartIndex() {
68                 if (totalSize == 0) {
69                         return 0;
70                 }
71                 return offset;
72         }
73         public int getEndIndex() {
74                 return offset + rows.size() - 1;
75         }
76         public int getTotalSize() {
77                 return totalSize;
78         }
79         public void nextPage() {
80                 loadSize();
81                 offset = offset + pageSize;
82                 if (totalSize >= 0 && offset > totalSize) {
83                         offset = offset - pageSize;
84                 }
85         }
86         public void previousPage() {
87                 offset = offset - pageSize;
88                 if (offset < 1) {
89                         offset = 1;
90                 }
91         }
92         public boolean hasNextPage() {
93                 if (table != null) {
94                         if (offset + pageSize <= totalSize) {
95                                 return true;
96                         }
97                         return false;
98                 }
99                 return hasMore;
100         }
101         public boolean hasPreviousPage() {
102                 if (offset > 1) {
103                         return true;
104                 }
105                 return false;
106         }
107         public String getTableCountQuery() {
108                 if (table != null) {
109                         Bookmark current = MultiSQLServer.getInstance().getConnected();
110                         return SQLHelper.getFullTableName(current, table);
111                 }
112                 return query;
113         }
114         public String getQuery() {
115                 if (table != null) {
116                         MultiSQLServer server = MultiSQLServer.getInstance();
117                         Bookmark current = server.getConnected();
118                         try {
119                                 DatabaseAdapter adapter = AdapterFactory.getInstance().getAdapter(current.getType());
120                                 return adapter.getShowTableQuery(DatabaseInfo.create(current), table) + extra.toString();
121                         } catch (NoSuchAdapterException e) {
122                                 throw new RuntimeException(e.toString());
123                         }
124                 }
125                 return query;
126         }
127         public void loadData() {
128                 loadSize();
129                 if (table != null) {
130                         if (offset > totalSize) {
131                                 offset = 1;
132                         }
133                 }
134                 String query = getQuery();
135     if (DEBUG) {
136                 System.out.println(offset + " to " + (offset + pageSize - 1));
137     }
138                 SQLResults results = helper.getResults(query, offset, offset + pageSize - 1, maxColumnSize, encoding);
139                 setData(results);
140         }
141         public void resetOffset() {
142                 offset = 1;
143         }
144         public void setData(SQLResults results) {
145                 int rowCount = results.getRowCount();
146                 int columnCount = results.getColumnCount();
147                 rows = new Vector();
148                 columnNames = new Vector();
149                 for (int col = 1; col <= columnCount; col++) {
150                         columnNames.addElement(results.getColumnName(col));
151                 }
152                 for (int row = 1; row <= rowCount; row++) {
153                         String rowData[] = new String[columnCount];
154                         for (int col = 1; col <= columnCount; col++) {
155                                 rowData[col - 1] = results.getElement(col, row).toString();
156                         }
157                         rows.addElement(rowData);
158                 }
159                 hasMore = results.hasMore();
160                 if (table == null && results.getMaxSize() >= 0) {
161                         if (offset > results.getMaxSize()) {
162                                 offset = 1;
163                                 loadData();
164                         }
165                 }
166         }
167         public void loadTable(Table table) {
168                 table.setHeaderVisible(true);
169                 for (int i = 0; i < columnNames.size(); i++) {
170                         TableColumn column = new TableColumn(table, SWT.NONE);
171                         column.setText(columnNames.elementAt(i).toString());
172                 }
173                 for (int i = 0; i < columnNames.size(); i++) {
174                         table.getColumn(i).pack();
175                 }
176                 for (int row = 0; row < rows.size(); row++) {
177                         TableItem item = new TableItem(table, SWT.NONE);
178                         String itemData[] = (String[]) rows.elementAt(row);
179                         item.setText(itemData);
180                 }
181                 for (int i = 0; i < columnNames.size(); i++) {
182                         table.getColumn(i).pack();
183                 }
184         }
185         
186         public int getPageSize() {
187                 return pageSize;
188         }
189         
190         public void setFilterSort(FilterSort extra) {
191                 this.extra = extra;
192         }
193         public String getTable() {
194                 return table;
195         }
196
197         public void setTable(String table) {
198                 this.table = table;
199         }
200         public void setQuery(String query) {
201                 this.query = query;
202         }
203         public String getEncoding() {
204                 return encoding;
205         }
206
207         public void setEncoding(String encoding) {
208                 this.encoding = encoding;
209         }
210         public String getStatusString() {
211                 String status = getStartIndex() + " to " + getEndIndex() + " of " +
212                                 getTotalSize();
213                 if (!encoding.equals(DEFAULT)) {
214                         status += " (" + encoding + ")";
215                 }
216                 String filterText = extra.toString();
217                 if (!filterText.equals("")) {
218                         status += " (" + filterText + ")";
219                 }
220                 if (pageSize == Integer.MAX_VALUE) {
221                         status += " (FULL)";
222                 }
223                 return status;
224         }
225 }