Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Java [игнор отключен] [закрыт для гостей] / JSF Проблема с выводом таблицы / 4 сообщений из 4, страница 1 из 1
17.11.2016, 12:10
    #39348972
YouNotImba
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
JSF Проблема с выводом таблицы
Добрый день !
Делаю простенький проект - форма редактирования таблицы в бд.

В классе, помеченном как @ManagedBean и @RequestScoped реализован метод :

Код: java
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
public ArrayList<BookManagedBean> getAllBooks() {

		ArrayList<BookManagedBean> allBooks = new ArrayList<>();

		try {
			conn = ConnectionManager.getInstance().getConnection();
			stmt = conn.prepareStatement("SELECT id,title,author FROM book");
			rs = stmt.executeQuery();
			while (rs.next()) {
				BookManagedBean bmb = new BookManagedBean();
				bmb.setId(rs.getInt("id"));
				bmb.setTitle(rs.getString("title"));
				bmb.setAuthor(rs.getString("author"));
				allBooks.add(bmb);
			}
		} catch (Exception e) {
			Logger.getLogger(BookManagedBean.class).log(Level.SEVERE, null, e);
		} finally {
			try {
				conn.close();
				stmt.close();
				rs.close();
			} catch (SQLException e) {
				Logger.getLogger(BookManagedBean.class).log(Level.SEVERE, null, e);
			}
		}
		return allBooks;
	}



Метод данные из базы дергает, лист возвращается не пустой.

В index.xhtml имеем :

Код: html
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
          "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
	xmlns:ui="http://java.sun.com/jsf/facelets"
	xmlns:h="http://java.sun.com/jsf/html"
	xmlns:fcore="http://java.sun.com/jsf/core">
<head>
<title><ui:insert name="title">Books list</ui:insert></title>
</head>

<h:body>

	<center>
		<fcore:view>
			<h:form>
				<h:dataTable var="list" value="#{bookManagedBean.getAllBooks()}" border="1" cellpadding="2"
					cellspacing="2">
					<h:column>
						<fcore:facet name="header">Book Id</fcore:facet>
						<h:inputText value="#{list.id}" />
					</h:column>
					<h:column>
						<fcore:facet name="header">Title</fcore:facet>
						<h:inputText value="#{list.title}" />
					</h:column>
					<h:column>
						<fcore:facet name="header">Author</fcore:facet>
						<h:inputText value="#{list.author}" />
					</h:column>
					<h:column>
						<fcore:facet name="header">Edit</fcore:facet>
						
					</h:column>
					<h:column>
						<fcore:facet name="header">Delete</fcore:facet>
						
					</h:column>
				</h:dataTable>
				<h:commandLink value = "Add Book" action = "aaa" />
			</h:form>
		</fcore:view>
	</center>
</h:body>

</html>



Приложение запускается, но данные не выводятся (только имена колонок).

В чем может быть проблема ?

ПС Делаю по аналогии с видео, там при таком же коде, все работает.

Спасибо !
...
Рейтинг: 0 / 0
17.11.2016, 12:42
    #39349004
забыл ник
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
JSF Проблема с выводом таблицы
YouNotImba,
Ваш геттер getAllBooks() скорее всего вызывается несколько раз в течение жиненного цикла jsf, сделайте его кэшем. if(dataLoaded) return data else readFromDB(). Это не относится скорее всего к вашей первоначальной проблеме, но это надо иметь ввиду. В остальном вроде код выглядит нормально
...
Рейтинг: 0 / 0
18.11.2016, 11:07
    #39349685
YouNotImba
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
JSF Проблема с выводом таблицы
Причину нашел : при вызове из index.xhtml метод кидает No suitable driver Exception.

Если запускать как java приложение - все работает правильно.

Драйвер лежит в WEB-INF/lib , в Lib'ах Glassfish'а и в classpath.

Где я не прав ? (=

Спасибо.
...
Рейтинг: 0 / 0
18.11.2016, 11:17
    #39349695
Blazkowicz
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
JSF Проблема с выводом таблицы
YouNotImbaДрайвер лежит в WEB-INF/lib , в Lib'ах Glassfish'а и в classpath.

Сразу 3 ошибки.
1. Использование Glassfish вместо любого другого бесплатного, но менее глючнего контейнера.
2. Библиотека должна лежать в одном месте, а не сразу в трех. Это чревато "странными" ошибками в будущем. Хотя нормальные современные контейнеры от этого защищаются.
3. В JEE приложении ссылка на DataSource надо получать из JNDI, а конфигурировать DataSource нужно средствами контейнера.
https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-usagenotes-glassfish-config.html
...
Рейтинг: 0 / 0
Форумы / Java [игнор отключен] [закрыт для гостей] / JSF Проблема с выводом таблицы / 4 сообщений из 4, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]