質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Q&A

解決済

2回答

5540閲覧

Spring+MirageSQLでトランザクションが開始しない

退会済みユーザー

退会済みユーザー

総合スコア0

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

0グッド

0クリップ

投稿2017/04/13 01:24

編集2017/04/13 09:38

Spring+MirageSQLでログイン処理を実装しようとしているのですが、
SQLを発行しようとすると、

java.lang.IllegalStateException: It seems not to be existing a transaction.

となってしまいます。

java

1@Controller 2public class LoginController { 3 public Player player; 4 5 @Autowired(required=true) 6 protected PlayerService playerService; 7 8 @RequestMapping(value = "/auth", method = RequestMethod.POST) 9 public String auth(Model model,@ModelAttribute("playerForm") PlayerForm playerForm) { 10 player = playerService.findByLoginId(playerForm.getLoginId()); 11 return "index"; 12 } 13}

java

1@Service 2public class PlayerService { 3 4 @Autowired 5 SqlManager sqlManager; 6 7 @SuppressWarnings("deprecation") 8 @Transactional 9 public Player findByLoginId(String loginId) { 10 return sqlManager.getResultListBySql(Player.class, "select * from player where loginId=?", loginId).get(0); 11 } 12 13}

プロキシによるAOPの弱点に記載されている状況と同じだと思うのですが、
具体的にどのように実装すればトランザクション管理の中でデータベースアクセスができるのでしょうか。

お忙しいところ申し訳ありませんがご教授願えませんでしょうか。

追記:
servlet-context.xmlがなかったのですが、中身から判断して
mvc-config.xmlを記載しておきます。

xml

1<?xml version="1.0" encoding="UTF-8"?> 2 3<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 4 xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" 5 xmlns:tx="http://www.springframework.org/schema/tx" 6 xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd 7 http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 8 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd 9 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> 10 11 <!-- Uncomment and your base-package here: 12 <context:component-scan 13 base-package="org.springframework.samples.web"/> --> 14 15 16 <mvc:annotation-driven /> 17 <mvc:resources mapping="/css/**" location="/WEB-INF/css/" /> 18 <mvc:resources mapping="/js/**" location="/WEB-INF/js/" /> 19 <context:component-scan base-package="cx.myhome.*********"/> 20 <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 21 <!-- Example: a logical view name of 'showMessage' is mapped to '/WEB-INF/jsp/showMessage.jsp' --> 22 <property name="prefix" value="/WEB-INF/view/"/> 23 <property name="suffix" value=".jsp"/> 24 </bean> 25<tx:annotation-driven /> 26</beans> 27

トランザクションマネージャの設定の記述があるのは
application-config.xmlでした。

xml

1<?xml version="1.0" encoding="UTF-8"?> 2 3<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 4 xmlns:context="http://www.springframework.org/schema/context" 5 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 6 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> 7 8 <!-- Uncomment and add your base-package here: 9 <context:component-scan 10 base-package="org.springframework.samples.service"/> --> 11<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> 12 <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 13 <property name="url" value="jdbc:mysql://localhost:3306/test" /> 14 <property name="username" value="****" /> 15 <property name="password" value="****" /> 16</bean> 17 18<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 19 <property name="dataSource" ref="dataSource"/> 20</bean> 21 22<bean id="connectionProvider" class="jp.sf.amateras.mirage.integration.spring.SpringConnectionProvider"> 23 <property name="transactionManager" ref="transactionManager" /> 24</bean> 25 26<bean id="dialect" class="jp.sf.amateras.mirage.dialect.MySQLDialect" /> 27 28<bean id="sqlManager" class="jp.sf.amateras.mirage.SqlManagerImpl"> 29 <property name="connectionProvider" ref="connectionProvider" /> 30 <property name="dialect" ref="dialect" /> 31</bean> 32</beans>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

間違ったトランザクションマネージャを使用している可能性があります。
servlet-context.xmlも提示していただけますか?

投稿2017/04/13 02:48

Clor

総合スコア883

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

0

ベストアンサー

spring-jdbcのバージョンが2系のままだったことに気づき、修正したところ
SQLが発行されるようになりました。

xml

1<spring-framework.version>3.2.6.RELEASE</spring-framework.version> 2<dependency> 3 <groupId>org.springframework</groupId> 4 <artifactId>spring-jdbc</artifactId> 5 <version>${spring-framework.version}</version> 6 </dependency>

ご迷惑をおかけして大変申し訳ありませんでした。

投稿2017/04/18 11:02

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問