MyBatis は、データ アクセス層の開発を簡素化するオープンソースの永続層フレームワークです。実際の開発では、デバッグや最適化を容易にするために、SQL クエリの実行時に MyBatis によって生成された特定の SQL ステートメントやパラメーター情報を表示する必要があることがよくあります。この記事では、開発者がデバッグできるように SQL クエリ情報をコンソールに出力するように MyBatis を構成する方法を紹介します。
まず、MyBatis 設定ファイル (mybatis-config.xml など) に次の設定を追加する必要があります:
<configuration> <!-- 其他配置 --> <!-- 开启日志输出 --> <settings> <setting name="logImpl" value="STDOUT_LOGGING"/> </settings> <!-- 配置日志输出级别 --> <settings> <setting name="logLevel" value="DEBUG"/> </settings> </configuration>
上記の設定では、logImpl# を設定します。 ## 値は
STDOUT_LOGGING でコンソールに出力されるログを指定し、
logLevel の値は
DEBUG に設定され、出力ログ レベルを DEBUG に指定します。 。このようにして、MyBatis の SQL クエリ情報をコンソールに出力できます。
@Mapper public interface UserMapper { @Select("SELECT * FROM user WHERE id = #{id}") @Options(statementType = StatementType.STATEMENT) User selectUserById(Long id); }
@Select アノテーションを使用して SQL クエリ ステートメントを指定し、
を渡します。 ${id} パラメータを参照します。同時に、SQL ステートメントを実行するための PreparedStatement の使用を指定する
@Options(statementType = StatementType.STATEMENT) も追加しました。この設定後、MyBatis は SQL クエリの実行時に特定の SQL ステートメントとパラメーター情報をコンソールに出力します。
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration); SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = userMapper.selectUserById(1L);
以上がMyBatis コンソールは SQL クエリ情報を出力しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。