# mybatipse **Repository Path**: mirrors/mybatipse ## Basic Information - **Project Name**: mybatipse - **Description**: Eclipse plugin adding support for MyBatis SQL Mapper Framework. - **Primary Language**: Unknown - **License**: EPL-1.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 11 - **Forks**: 1 - **Created**: 2017-04-03 - **Last Updated**: 2026-02-28 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README MyBatipse : Eclipse plugin for MyBatis ======= [MyBatis](http://mybatis.org/) is a popular SQL Mapper framework. And __MyBatipse__ is an Eclipse plug-in which provids content assists and validations when editing MyBatis related files. ## Features ### XML Editor Enhancements #### Auto-completion - Mapper namespace : Calculated from the path. ![autocomplete namespace](screen/ac-ns1.png)![autocomplete namespace](screen/ac-ns2.png) - Java class/Type alias : Propose Java classes and Type Aliases (translucent icons). Camelcase match is supported. [1] [2] ![autocomplete class](screen/ac-class.png) ![autocomplete class](screen/ac-class-cc.png) - Java property : Propose properties of the parent java class. Nested properties are supported. ![autocomplete property](screen/ac-prop1.png) ![autocomplete property](screen/ac-prop2.png) - Statement ID : If corresponding mapper interface exists, propose the method name as a statement ID. ![autocomplete statement id](screen/ac-stmt.png) - Reference to resultMap/select/sql : Propose ID of the referenced resultMap/select/sql. External reference is supported (blue icons). ![autocomplete reference](screen/ac-ref.png) - Parameter properties : #{} and ${} in select/insert/udpate/delte statements. Also works in some attributes. ![autocomplete properties](screen/ac-stmt-prop-xml.png) ![autocomplete properties 2](screen/ac-prop-test.png) - javaType, jdbcType, typeHandler in #{} ![autocomplete jdbcType](screen/ac-jdbc-type.png) - Result elements in resultMap/collection/association : Generates elements for the parent java class properties. ![autocomplete results](screen/ac-results.png) - setting name and value in XML config. ![autocomplete setting](screen/ac-setting-name.png) ![autocomplete setting](screen/ac-setting-value.png) - __[1]__ For better performance, classes in the application libraries (loaded as JARs) are listed only when at least one package segment is specified. - __[2]__ There is a limitation for the type alias support. Basically, if type aliases are registered using Java API, they are not automatically detected. As a workaround, you can register type aliases in MyBatipse's preference. See the _Configuration_ section. #### Hyperlinks - To referenced resultMap/select/sql element. External reference is supported. ![link to external reference](screen/hl-refid.png) - From Java mapper interface to XML mapper element. ![link to xml mapper](screen/hl-xml-mapper.png) - From Java mapper method to XML mapper element. ![link to xml statement](screen/hl-xml-statement.png) - From XML statement id to Java mapper method. ![link to java method](screen/hl-java-method.png) - Result map id or select statement id specified in Java annotation. #### Validation - Missing TypeAlias, Java class/property. - Missing resultMap/select/sql ID. - etc. ![refid error](screen/err-refid.png) ![problem view](screen/prblm-view.png) #### Mapper Declaration View - This feature is ported from [MyBatis Editor plugin](https://code.google.com/a/eclipselabs.org/p/mybatiseditor/) by @peterhendriks . ![sqlview xml](screen/sqlview-xml.png) ![sqlview](screen/sqlview.png) ### Java Editor Enhancements #### Auto-completion - Parameter properties : #{} and ${} in select/insert/udpate/delte annotations. ![autocomplete properties in java](screen/ac-stmt-prop-java.png) - Return type properties in ```@Result``` ![autocomplete return type properties in java](screen/ac-result-prop-java.png) - keyProperty in ```@Options``` and ```@SelectKey``` ![autocomplete return type properties in java](screen/ac-options-keyprop-java.png) ![autocomplete return type properties in java](screen/ac-selkey-keyprop-java.png) - javaType, jdbcType, typeHandler in #{} : See the XML example. - Reference to resultMap in ```@ResultMap``` and resultMap attribute of ```@Arg``` ![autocomplete resultmap annotation](screen/ac-rmap-java.png) - select attribute of ```@Arg```, ```@Many``` and ```@One``` ![autocomplete select](screen/ac-select-java.png) #### Quick Assist Put the cursor on the statement method name and press cmd + 1 (or ctrl + 1) to trigger Quick Assist. - You can add ```@Param``` to method parameters. ![param-annotation1](screen/qa-add-param1.png) ![param-annotation2](screen/qa-add-param2.png) - You can copy annotation statement into the clipboard. ![param-annotation1](screen/qa-copy-statement.png) - You can move annotation statement to XML mapper. ![move-statement](screen/qa-move-statement.png) - You can move `@Results` annotation to `` in XML mapper. ![move-resultmap](screen/qa-move-resultmap.png) #### Validation - `@ResultMap` : invalid resultMap ID. - `select` attribute of `@One` or `@Many` : invalid statement ID. ### Rename Refactoring - Renaming resultMap/statement/sql ID updates its references in Java and XML mappers. - In XML mapper, right click -> Refactor -> Rename MyBatis element. ![param-annotation1](screen/refactor-rename-xml.png) - In Java mapper, right click -> MyBatis Refactor -> Rename MyBatis element. ![param-annotation1](screen/refactor-rename-java.png) - Renaming a Java mapper method also updates its references. ### Miscellaneous - Wizard to create a new XML mapper file. ![wizard-xml-mapper](screen/wizard-xml-mapper.png) - Smart-copy menu in Console View to copy SQL statement in an executable form. For example, if you select and copy the following debug output ... ![smart-copy-console](screen/smart-copy-console.png) ... and the following statement is copied to the clipboard (be sure to include the first `==>` and `<==` in the selection as the image above). ```sql insert into users values(2, 'User2') ``` ## Configuration ### XML mapper location - MyBatipse searches XML mapper files under your project's __Source Folder__. To make a directory __Source Folder__, right click the directory in the package explorer and choose __Build Path__ -> __Use as Source Folder__ from the menu. ### MyBatis Nature - By default, each file is validated when it's saved, but you would want to validate the XML mapper when the related Java classes are updated as well. For that purpose, MyBatipse provides a custom nature __MyBatis Nature__. To add the nature, right click the project in the package explorer and choose __Configure__ -> __Add MyBatis Nature__ from the menu. ![nature](screen/nature.png) ### Annotation Processing - To validate annotation value, you need to enable __annotation processing__. Open __Project__ -> __Properties__ and select __Java Compiler__ -> __Annotation Processing__ in the left column. Check both __Enable annotation processing__ and __Enable processing in editor__. ### Type Alias - Type alias are automatically detected _if_ they are registered using XML config file (both mybatis and mybatis-spring config is supported). If you register type aliases in Java code, MyBatipse cannot detect them. As a workaround, you can register custom type aliases in the project setting (Open __Project__ -> __Properties__ menu and select __MyBatipse__ from the left column). ![type aliases](screen/pref-alias.png) For example, with the above settings: - The first entry registers all the classes in ```com.example.domain``` package as type aliases. You can use wildcard to specify multiple packages (e.g. `com.example.*.domain`). - The second entry registers the single class ```domain.Person```. - The third entry registers the single class ```domain.SomeLongNamedBean``` under the alias ```SomeBean```. - Note that, in any case, MyBatipse respects ```@Alias``` annotation if it exists. ### Java 8 `-parameters` compiler option support - If 'Store information about method parameters' option is enabled in the Java Compiler -> Classfile Generation setting, MyBatipse proposes the declared method parameter names. ![xml proposal order](screen/actual-parameters.png) ## Tips - To move MyBatis proposals to the top of the XML proposal list, quit Eclipse and open the following file in the workspace: ```.metadata/.plugins/org.eclipse.core.runtime/.settings/org.eclipse.wst.xml.ui.prefs``` Find the line started with ```xml_content_assist_default_page_sort_order=``` and insert ```net.harawata.mybatis.proposalCategory.xml\u0000``` right after the equal sign. ![xml proposal order](screen/xml-proposal-order.png) ## Installation There are several ways to install MyBatipse. - Drag this button [![drag-to-install button](http://marketplace.eclipse.org/misc/installbutton.png)](http://marketplace.eclipse.org/marketplace-client-intro?mpc_install=1467819) from browser to your Eclipse workbench (i.e. window). - Choose __Eclipse Marketplace...__ in __Help__ menu of your Eclipse and search __MyBatipse__. - Choose __Install New Software...__ in __Help__ menu and enter the following URL. https://harawata.github.io/eclipse-site/ - For offline installation, see [here](https://github.com/mybatis/mybatipse/issues/88#issuecomment-411817801). ## Bugs, questions, suggestions, etc. Please use the [issue tracker](https://github.com/harawata/mybatipse/issues). ## License MyBatipse is licensed under [__Eclipse Public License 1.0__](http://www.eclipse.org/legal/epl-v10.html).