在 MyBatis 中使用 XML 文件編寫(xiě) SQL 語(yǔ)句時(shí),可以使用以下技巧來(lái)編寫(xiě)創(chuàng)建表的 SQL 腳本:
<![CDATA[ ]]>
標(biāo)簽包裹 SQL 語(yǔ)句,以避免 XML 解析器解析特殊字符。<sql id="createTable">
<![CDATA[
CREATE TABLE IF NOT EXISTS table_name (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50) NOT NULL
);
]]>
</sql>
<sql id="createTable">
<![CDATA[
CREATE TABLE IF NOT EXISTS ${tableName} (
${column1} INT PRIMARY KEY AUTO_INCREMENT,
${column2} VARCHAR(50) NOT NULL
);
]]>
</sql>
<include>
標(biāo)簽引入其他 SQL 片段,以便復(fù)用已定義的 SQL 語(yǔ)句段。<sql id="tableColumns">
<![CDATA[
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50) NOT NULL
]]>
</sql>
<sql id="createTable">
<![CDATA[
CREATE TABLE IF NOT EXISTS table_name (
<include refid="tableColumns" />
);
]]>
</sql>
${}
占位符來(lái)引用變量,以便在運(yùn)行時(shí)動(dòng)態(tài)替換變量的值。<sql id="createTable">
<![CDATA[
CREATE TABLE IF NOT EXISTS ${tableName} (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(50) NOT NULL
);
]]>
</sql>
通過(guò)以上技巧,可以更加靈活和高效地編寫(xiě) MyBatis 中的創(chuàng)建表腳本。