<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>Dynamicsql on Micha Kops&#39; Tech Notes</title>
    <link>https://www.hascode.com/tags/dynamicsql/</link>
    <description>Recent content in Dynamicsql on Micha Kops&#39; Tech Notes</description>
    <generator>Hugo</generator>
    <language>en</language>
    <copyright>Copyright © 2010 - 2025 Micha Kops. #e9d956c0c0154a221ad83c925346a8fa0e72f866</copyright>
    <lastBuildDate>Mon, 01 Mar 2010 00:00:00 +0100</lastBuildDate>
    <atom:link href="https://www.hascode.com/tags/dynamicsql/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>MyBatis Snippets</title>
      <link>https://www.hascode.com/mybatis-snippets/</link>
      <pubDate>Mon, 01 Mar 2010 00:00:00 +0100</pubDate>
      <guid>https://www.hascode.com/mybatis-snippets/</guid>
      <description>&lt;div class=&#34;sect1&#34;&gt;
&lt;h2 id=&#34;_use_list_of_parameters_in_annotation_based_query&#34;&gt;Use List of Parameters in Annotation-based Query&lt;/h2&gt;
&lt;div class=&#34;sectionbody&#34;&gt;
&lt;div class=&#34;paragraph&#34;&gt;
&lt;p&gt;Possible using MyBatis &lt;a href=&#34;https://mybatis.org/mybatis-3/dynamic-sql.html&#34;&gt;Dynamic SQL feature&lt;/a&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;div class=&#34;listingblock&#34;&gt;
&lt;div class=&#34;content&#34;&gt;
&lt;pre class=&#34;highlight&#34;&gt;&lt;code class=&#34;language-java&#34; data-lang=&#34;java&#34;&gt;package com.hascode.example.mybatis;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper
public interface SampleMapper {

    @Select({&amp;#34;&amp;lt;script&amp;gt;&amp;#34;,
             &amp;#34;SELECT sample.bar&amp;#34;,
             &amp;#34;FROM sampletable sample&amp;#34;,
             &amp;#34;WHERE sample.id IN&amp;#34;,
            &amp;#34;&amp;lt;foreach item=&amp;#39;item&amp;#39; index=&amp;#39;index&amp;#39; collection=&amp;#39;ids&amp;#39;&amp;#34;,
            &amp;#34;open=&amp;#39;(&amp;#39; separator=&amp;#39;,&amp;#39; close=&amp;#39;)&amp;#39;&amp;gt;&amp;#34;,
            &amp;#34;#{item}&amp;#34;,
            &amp;#34;&amp;lt;/foreach&amp;gt;&amp;#34;,
            &amp;#34;&amp;lt;/script&amp;gt;&amp;#34;})
    List&amp;lt;Foo&amp;gt; getSamplesMatchingIds(@Param(&amp;#34;ids&amp;#34;) List&amp;lt;String&amp;gt; ids);
}&lt;/code&gt;&lt;/pre&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;div class=&#34;paragraph&#34;&gt;
&lt;p&gt;The mapper may now be used with a list of parameter objects:&lt;/p&gt;
&lt;/div&gt;
&lt;div class=&#34;listingblock&#34;&gt;
&lt;div class=&#34;content&#34;&gt;
&lt;pre class=&#34;highlight&#34;&gt;&lt;code class=&#34;language-java&#34; data-lang=&#34;java&#34;&gt;var samples = sampleMapper.getSamplesMatchingIds(List.of(&amp;#34;24059e5b-aa07-424d-855e-50f499b8f697&amp;#34;, &amp;#34;65140fc0-fc9f-42d2-9531-5e5d6caeba30&amp;#34;));&lt;/code&gt;&lt;/pre&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;
&lt;div class=&#34;sect1&#34;&gt;
&lt;h2 id=&#34;_call_a_procedure&#34;&gt;Call a Procedure&lt;/h2&gt;
&lt;div class=&#34;sectionbody&#34;&gt;
&lt;div class=&#34;listingblock&#34;&gt;
&lt;div class=&#34;content&#34;&gt;
&lt;pre class=&#34;highlight&#34;&gt;&lt;code class=&#34;language-java&#34; data-lang=&#34;java&#34;&gt;package com.hascode.example.mybatis;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Options;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.mapping.StatementType;

@Mapper
public interface SampleMapper {

    @Select(&amp;#34;CALL SCHEMA.CL.setScope(#{scope})&amp;#34;)
    @Options(statementType = StatementType.CALLABLE)
    void setScope(int scope);
}&lt;/code&gt;&lt;/pre&gt;
&lt;/div&gt;</description>
    </item>
  </channel>
</rss>
