{"id":62538,"date":"2026-01-20T07:49:49","date_gmt":"2026-01-19T23:49:49","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/62538.html"},"modified":"2026-01-20T07:49:49","modified_gmt":"2026-01-19T23:49:49","slug":"deepseek-preparedstatement-%e4%b8%8e-statement-%e5%85%a8%e9%9d%a2%e5%af%b9%e6%af%94","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/62538.html","title":{"rendered":"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4"},"content":{"rendered":"<h2>PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4<\/h2>\n<h3>1. \u57fa\u7840\u533a\u522b<\/h3>\n<p><span class=\"token keyword\">import<\/span> <span class=\"token import\"><span class=\"token namespace\">java<span class=\"token punctuation\">.<\/span>sql<span class=\"token punctuation\">.<\/span><\/span><span class=\"token operator\">*<\/span><\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">public<\/span> <span class=\"token keyword\">class<\/span> <span class=\"token class-name\">StatementVsPreparedStatement<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">main<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> args<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> url <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;jdbc:mysql:\/\/localhost:3306\/testdb&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;root&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> password <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;password&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">Class<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">forName<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;com.mysql.cj.jdbc.Driver&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">Connection<\/span> conn <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">DriverManager<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">getConnection<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">,<\/span> password<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token function\">demoStatement<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token function\">demoPreparedStatement<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token function\">demoBatchOperations<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Exception<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            e<span class=\"token punctuation\">.<\/span><span class=\"token function\">printStackTrace<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * Statement \u57fa\u672c\u7528\u6cd5<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">demoStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;&#061;&#061;&#061; Statement \u6f14\u793a &#061;&#061;&#061;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">Statement<\/span> stmt <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">null<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ 1. \u6267\u884c\u67e5\u8be2<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> query <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT id, name, email FROM users WHERE status &#061; &#039;ACTIVE&#039;&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span>query<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token keyword\">while<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;ID: %d, Name: %s, Email: %s%n&#034;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                    rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;id&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                    rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;name&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                    rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;email&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n            rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ 2. \u6267\u884c\u66f4\u65b0<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> update <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;UPDATE users SET last_login &#061; NOW() WHERE status &#061; &#039;ACTIVE&#039;&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">int<\/span> rowsUpdated <span class=\"token operator\">&#061;<\/span> stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeUpdate<\/span><span class=\"token punctuation\">(<\/span>update<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u66f4\u65b0\u884c\u6570: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> rowsUpdated<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ 3. \u6267\u884c\u4efb\u610fSQL<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;CREATE TABLE IF NOT EXISTS temp_table (id INT, name VARCHAR(50))&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">finally<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>stmt <span class=\"token operator\">!&#061;<\/span> <span class=\"token keyword\">null<\/span><span class=\"token punctuation\">)<\/span> stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * PreparedStatement \u57fa\u672c\u7528\u6cd5<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">demoPreparedStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\\\\n&#061;&#061;&#061; PreparedStatement \u6f14\u793a &#061;&#061;&#061;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 1. \u67e5\u8be2\u793a\u4f8b<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> query <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT * FROM users WHERE id &#061; ? AND status &#061; ?&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">null<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>query<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1001<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>     <span class=\"token comment\">\/\/ \u8bbe\u7f6e\u7b2c\u4e00\u4e2a\u53c2\u6570<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;ACTIVE&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u8bbe\u7f6e\u7b2c\u4e8c\u4e2a\u53c2\u6570<\/span><\/p>\n<p>            <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">while<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;User: %s, Email: %s%n&#034;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                    rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;name&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                    rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;email&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n            rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">finally<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>pstmt <span class=\"token operator\">!&#061;<\/span> <span class=\"token keyword\">null<\/span><span class=\"token punctuation\">)<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 2. \u63d2\u5165\u793a\u4f8b<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> insert <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;INSERT INTO users (name, email, password, created_at) VALUES (?, ?, ?, ?)&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">PreparedStatement<\/span> insertStmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>insert<span class=\"token punctuation\">,<\/span><br \/>\n                <span class=\"token class-name\">Statement<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">RETURN_GENERATED_KEYS<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;\u5f20\u4e09&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;zhangsan&#064;example.com&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;encrypted_password&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setTimestamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">4<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">Timestamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token keyword\">int<\/span> affectedRows <span class=\"token operator\">&#061;<\/span> insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeUpdate<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u63d2\u5165\u884c\u6570: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> affectedRows<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u83b7\u53d6\u81ea\u589eID<\/span><br \/>\n            <span class=\"token class-name\">ResultSet<\/span> keys <span class=\"token operator\">&#061;<\/span> insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">getGeneratedKeys<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>keys<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token keyword\">int<\/span> generatedId <span class=\"token operator\">&#061;<\/span> keys<span class=\"token punctuation\">.<\/span><span class=\"token function\">getInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u751f\u6210\u7684ID: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> generatedId<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n            keys<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 3. \u66f4\u65b0\u793a\u4f8b<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> update <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;UPDATE users SET last_login &#061; ?, login_count &#061; login_count &#043; 1 WHERE id &#061; ?&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">PreparedStatement<\/span> updateStmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>update<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            updateStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setTimestamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">Timestamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            updateStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1001<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token keyword\">int<\/span> rows <span class=\"token operator\">&#061;<\/span> updateStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeUpdate<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u66f4\u65b0\u7528\u6237\u767b\u5f55\u4fe1\u606f&#xff0c;\u5f71\u54cd\u884c\u6570: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> rows<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h3>2. SQL\u6ce8\u5165\u6f14\u793a\u4e0e\u9632\u62a4<\/h3>\n<p><span class=\"token keyword\">import<\/span> <span class=\"token import\"><span class=\"token namespace\">java<span class=\"token punctuation\">.<\/span>sql<span class=\"token punctuation\">.<\/span><\/span><span class=\"token operator\">*<\/span><\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">public<\/span> <span class=\"token keyword\">class<\/span> <span class=\"token class-name\">SQLInjectionDemo<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * Statement \u7684 SQL \u6ce8\u5165\u6f0f\u6d1e\u6f14\u793a<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">vulnerableLogin<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">String<\/span> username<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">String<\/span> password<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u274c \u5371\u9669\u5199\u6cd5&#xff1a;\u5bb9\u6613\u53d7\u5230SQL\u6ce8\u5165\u653b\u51fb<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT * FROM users WHERE username &#061; &#039;&#034;<\/span> <span class=\"token operator\">&#043;<\/span> username <span class=\"token operator\">&#043;<\/span><br \/>\n                    <span class=\"token string\">&#034;&#039; AND password &#061; &#039;&#034;<\/span> <span class=\"token operator\">&#043;<\/span> password <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034;&#039;&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u6267\u884c\u7684SQL: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">Statement<\/span> stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u767b\u5f55\u6210\u529f&#xff01;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">else<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u767b\u5f55\u5931\u8d25&#xff01;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * PreparedStatement \u9632\u6b62 SQL \u6ce8\u5165<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">safeLogin<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">String<\/span> username<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">String<\/span> password<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u2705 \u5b89\u5168\u5199\u6cd5&#xff1a;\u4f7f\u7528 PreparedStatement<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT * FROM users WHERE username &#061; ? AND password &#061; ?&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> username<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> password<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u6267\u884c\u7684SQL: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> pstmt<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u5b89\u5168\u767b\u5f55\u6210\u529f&#xff01;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">else<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u5b89\u5168\u767b\u5f55\u5931\u8d25&#xff01;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * SQL\u6ce8\u5165\u653b\u51fb\u793a\u4f8b<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">demonstrateInjection<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> url <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;jdbc:mysql:\/\/localhost:3306\/testdb&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;root&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> password <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;password&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">Connection<\/span> conn <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">DriverManager<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">getConnection<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">,<\/span> password<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;&#061;&#061;&#061; SQL\u6ce8\u5165\u653b\u51fb\u6f14\u793a &#061;&#061;&#061;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6b63\u5e38\u8f93\u5165<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\\\\n1. \u6b63\u5e38\u767b\u5f55:&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token function\">vulnerableLogin<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;admin&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;123456&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ SQL\u6ce8\u5165\u653b\u51fb<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\\\\n2. SQL\u6ce8\u5165\u653b\u51fb:&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u8f93\u5165: admin&#039; &#8212;<\/span><br \/>\n        <span class=\"token comment\">\/\/ SQL\u4f1a\u53d8\u6210: SELECT * FROM users WHERE username &#061; &#039;admin&#039; &#8211;&#039; AND password &#061; &#039;xxx&#039;<\/span><br \/>\n        <span class=\"token function\">vulnerableLogin<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;admin&#039; &#8211;&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;\u4efb\u610f\u5bc6\u7801&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u66f4\u5371\u9669\u7684\u6ce8\u5165<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\\\\n3. \u66f4\u5371\u9669\u7684\u6ce8\u5165:&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u8f93\u5165: &#039; OR &#039;1&#039;&#061;&#039;1<\/span><br \/>\n        <span class=\"token function\">vulnerableLogin<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;&#039; OR &#039;1&#039;&#061;&#039;1&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;&#039; OR &#039;1&#039;&#061;&#039;1&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u4f7f\u7528 PreparedStatement \u9632\u6b62\u6ce8\u5165<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\\\\n4. \u4f7f\u7528 PreparedStatement \u9632\u6b62\u6ce8\u5165:&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token function\">safeLogin<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;admin&#039; &#8211;&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;\u4efb\u610f\u5bc6\u7801&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * \u6279\u91cf\u6ce8\u5165\u98ce\u9669<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">batchInjectionRisk<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u274c \u5371\u9669&#xff1a;\u76f4\u63a5\u62fc\u63a5SQL<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> userInput <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;test&#039;; DROP TABLE users; &#8211;&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;INSERT INTO logs (message) VALUES (&#039;&#034;<\/span> <span class=\"token operator\">&#043;<\/span> userInput <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034;&#039;)&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">Statement<\/span> stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u53ef\u80fd\u6267\u884c\u6076\u610fSQL<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u2705 \u5b89\u5168&#xff1a;\u4f7f\u7528 PreparedStatement<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> safeSql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;INSERT INTO logs (message) VALUES (?)&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>safeSql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> userInput<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u53ea\u4f1a\u4f5c\u4e3a\u5b57\u7b26\u4e32\u503c\u5904\u7406<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeUpdate<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">main<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> args<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token function\">demonstrateInjection<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">SQLException<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            e<span class=\"token punctuation\">.<\/span><span class=\"token function\">printStackTrace<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h3>3. \u6027\u80fd\u5bf9\u6bd4\u4e0e\u6279\u91cf\u64cd\u4f5c<\/h3>\n<p><span class=\"token keyword\">import<\/span> <span class=\"token import\"><span class=\"token namespace\">java<span class=\"token punctuation\">.<\/span>sql<span class=\"token punctuation\">.<\/span><\/span><span class=\"token operator\">*<\/span><\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> <span class=\"token import\"><span class=\"token namespace\">java<span class=\"token punctuation\">.<\/span>util<span class=\"token punctuation\">.<\/span><\/span><span class=\"token operator\">*<\/span><\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">public<\/span> <span class=\"token keyword\">class<\/span> <span class=\"token class-name\">PerformanceComparison<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * Statement \u6279\u91cf\u63d2\u5165 &#8211; \u6027\u80fd\u8f83\u5dee<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">batchInsertWithStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">User<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> users<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token keyword\">long<\/span> startTime <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">Statement<\/span> stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">User<\/span> user <span class=\"token operator\">:<\/span> users<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token comment\">\/\/ \u6bcf\u6b21\u90fd\u9700\u8981\u62fc\u63a5SQL<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">String<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">format<\/span><span class=\"token punctuation\">(<\/span><br \/>\n                <span class=\"token string\">&#034;INSERT INTO users (name, email, age) VALUES (&#039;%s&#039;, &#039;%s&#039;, %d)&#034;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                user<span class=\"token punctuation\">.<\/span>name<span class=\"token punctuation\">.<\/span><span class=\"token function\">replace<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;&#039;&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;&#039;&#039;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u9700\u8981\u624b\u52a8\u8f6c\u4e49<\/span><br \/>\n                user<span class=\"token punctuation\">.<\/span>email<span class=\"token punctuation\">.<\/span><span class=\"token function\">replace<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;&#039;&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;&#039;&#039;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span><br \/>\n                user<span class=\"token punctuation\">.<\/span>age<br \/>\n            <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeUpdate<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">long<\/span> endTime <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;Statement \u6279\u91cf\u63d2\u5165 %d \u6761\u6570\u636e\u8017\u65f6: %d ms%n&#034;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            users<span class=\"token punctuation\">.<\/span><span class=\"token function\">size<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> endTime <span class=\"token operator\">&#8211;<\/span> startTime<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * PreparedStatement \u6279\u91cf\u63d2\u5165 &#8211; \u6027\u80fd\u8f83\u597d<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">batchInsertWithPreparedStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">User<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> users<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token keyword\">long<\/span> startTime <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;INSERT INTO users (name, email, age) VALUES (?, ?, ?)&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">User<\/span> user <span class=\"token operator\">:<\/span> users<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">.<\/span>name<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>    <span class=\"token comment\">\/\/ \u81ea\u52a8\u5904\u7406\u8f6c\u4e49<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">.<\/span>email<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>   <span class=\"token comment\">\/\/ \u81ea\u52a8\u5904\u7406\u8f6c\u4e49<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">.<\/span>age<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">addBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u6dfb\u52a0\u5230\u6279\u5904\u7406<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token keyword\">int<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> results <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">long<\/span> endTime <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;PreparedStatement \u6279\u91cf\u63d2\u5165 %d \u6761\u6570\u636e\u8017\u65f6: %d ms%n&#034;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            users<span class=\"token punctuation\">.<\/span><span class=\"token function\">size<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> endTime <span class=\"token operator\">&#8211;<\/span> startTime<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u68c0\u67e5\u6267\u884c\u7ed3\u679c<\/span><br \/>\n        <span class=\"token keyword\">int<\/span> successCount <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> result <span class=\"token operator\">:<\/span> results<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>result <span class=\"token operator\">&gt;&#061;<\/span> <span class=\"token number\">0<\/span> <span class=\"token operator\">||<\/span> result <span class=\"token operator\">&#061;&#061;<\/span> <span class=\"token class-name\">Statement<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">SUCCESS_NO_INFO<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                successCount<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u6210\u529f\u63d2\u5165: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> successCount <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034; \u6761\u8bb0\u5f55&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * \u4f7f\u7528\u4e8b\u52a1\u7684\u6279\u91cf\u63d2\u5165<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">batchInsertWithTransaction<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">User<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> users<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token keyword\">boolean<\/span> originalAutoCommit <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">getAutoCommit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">long<\/span> startTime <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">setAutoCommit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token boolean\">false<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u5f00\u59cb\u4e8b\u52a1<\/span><\/p>\n<p>            <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;INSERT INTO users (name, email, age) VALUES (?, ?, ?)&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span> i <span class=\"token operator\">&lt;<\/span> users<span class=\"token punctuation\">.<\/span><span class=\"token function\">size<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token class-name\">User<\/span> user <span class=\"token operator\">&#061;<\/span> users<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">.<\/span>name<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">.<\/span>email<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">.<\/span>age<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">addBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>                <span class=\"token comment\">\/\/ \u6bcf1000\u6761\u6267\u884c\u4e00\u6b21\u6279\u5904\u7406<\/span><br \/>\n                <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>i <span class=\"token operator\">%<\/span> <span class=\"token number\">1000<\/span> <span class=\"token operator\">&#061;&#061;<\/span> <span class=\"token number\">0<\/span> <span class=\"token operator\">&amp;&amp;<\/span> i <span class=\"token operator\">&gt;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                    pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">clearBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><\/p>\n<p>            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u6267\u884c\u5269\u4f59\u7684\u6279\u5904\u7406<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">commit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>         <span class=\"token comment\">\/\/ \u63d0\u4ea4\u4e8b\u52a1<\/span><\/p>\n<p>            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">SQLException<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">rollback<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>  <span class=\"token comment\">\/\/ \u53d1\u751f\u5f02\u5e38\u65f6\u56de\u6eda<\/span><br \/>\n            <span class=\"token keyword\">throw<\/span> e<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">finally<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">setAutoCommit<\/span><span class=\"token punctuation\">(<\/span>originalAutoCommit<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token keyword\">long<\/span> endTime <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u5e26\u4e8b\u52a1\u7684\u6279\u91cf\u63d2\u5165 %d \u6761\u6570\u636e\u8017\u65f6: %d ms%n&#034;<\/span><span class=\"token punctuation\">,<\/span><br \/>\n            users<span class=\"token punctuation\">.<\/span><span class=\"token function\">size<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span> endTime <span class=\"token operator\">&#8211;<\/span> startTime<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * Statement \u4e0e PreparedStatement \u6027\u80fd\u5bf9\u6bd4<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">performanceTest<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> url <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;jdbc:mysql:\/\/localhost:3306\/testdb&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;root&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> password <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;password&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">Connection<\/span> conn <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">DriverManager<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">getConnection<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">,<\/span> password<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u51c6\u5907\u6d4b\u8bd5\u6570\u636e<\/span><br \/>\n        <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">User<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> testUsers <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">generateTestUsers<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6e05\u7406\u6d4b\u8bd5\u8868<\/span><br \/>\n        <span class=\"token class-name\">Statement<\/span> stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;CREATE TABLE IF NOT EXISTS users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50), email VARCHAR(100), age INT)&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;TRUNCATE TABLE users&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;&#061;&#061;&#061; \u6027\u80fd\u5bf9\u6bd4\u6d4b\u8bd5 &#061;&#061;&#061;&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6d4b\u8bd51: Statement<\/span><br \/>\n        <span class=\"token function\">batchInsertWithStatement<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> testUsers<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6e05\u7406\u6570\u636e<\/span><br \/>\n        stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;TRUNCATE TABLE users&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6d4b\u8bd52: PreparedStatement<\/span><br \/>\n        <span class=\"token function\">batchInsertWithPreparedStatement<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> testUsers<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6e05\u7406\u6570\u636e<\/span><br \/>\n        stmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">createStatement<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;TRUNCATE TABLE users&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        stmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6d4b\u8bd53: PreparedStatement &#043; \u4e8b\u52a1<\/span><br \/>\n        <span class=\"token function\">batchInsertWithTransaction<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> testUsers<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">private<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">User<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> <span class=\"token function\">generateTestUsers<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> count<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">User<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> users <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">ArrayList<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">Random<\/span> random <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">Random<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span> i <span class=\"token operator\">&lt;<\/span> count<span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">User<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">User<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            user<span class=\"token punctuation\">.<\/span>name <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;User&#034;<\/span> <span class=\"token operator\">&#043;<\/span> i<span class=\"token punctuation\">;<\/span><br \/>\n            user<span class=\"token punctuation\">.<\/span>email <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;user&#034;<\/span> <span class=\"token operator\">&#043;<\/span> i <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034;&#064;example.com&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            user<span class=\"token punctuation\">.<\/span>age <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">20<\/span> <span class=\"token operator\">&#043;<\/span> random<span class=\"token punctuation\">.<\/span><span class=\"token function\">nextInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">50<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            users<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>user<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> users<span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">class<\/span> <span class=\"token class-name\">User<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> name<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> email<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">int<\/span> age<span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">main<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> args<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token function\">performanceTest<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">SQLException<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            e<span class=\"token punctuation\">.<\/span><span class=\"token function\">printStackTrace<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h3>4. \u9ad8\u7ea7\u529f\u80fd\u4e0e\u6700\u4f73\u5b9e\u8df5<\/h3>\n<p><span class=\"token keyword\">import<\/span> <span class=\"token import\"><span class=\"token namespace\">java<span class=\"token punctuation\">.<\/span>sql<span class=\"token punctuation\">.<\/span><\/span><span class=\"token operator\">*<\/span><\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> <span class=\"token import\"><span class=\"token namespace\">java<span class=\"token punctuation\">.<\/span>math<span class=\"token punctuation\">.<\/span><\/span><span class=\"token class-name\">BigDecimal<\/span><\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p><span class=\"token keyword\">public<\/span> <span class=\"token keyword\">class<\/span> <span class=\"token class-name\">AdvancedFeatures<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * PreparedStatement \u9ad8\u7ea7\u529f\u80fd<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">demoAdvancedFeatures<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 1. \u8bbe\u7f6e\u67e5\u8be2\u8d85\u65f6<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT * FROM large_table WHERE status &#061; ?&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setQueryTimeout<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">30<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ 30\u79d2\u8d85\u65f6<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;ACTIVE&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 2. \u8bbe\u7f6e\u83b7\u53d6\u884c\u6570\u9650\u5236<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setMaxRows<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u6700\u591a\u83b7\u53d61000\u884c<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 3. \u8bbe\u7f6e\u83b7\u53d6\u5927\u5c0f<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setFetchSize<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u6bcf\u6b21\u4ece\u6570\u636e\u5e93\u83b7\u53d6100\u884c<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 4. \u5904\u7406\u5404\u79cd\u6570\u636e\u7c7b\u578b<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> insertSQL <span class=\"token operator\">&#061;<\/span> <span class=\"token triple-quoted-string string\">&#034;&#034;&#034;<br \/>\n            INSERT INTO products (<br \/>\n                name, price, quantity, available,<br \/>\n                created_at, description, metadata<br \/>\n            ) VALUES (?, ?, ?, ?, ?, ?, ?)<br \/>\n            &#034;&#034;&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">PreparedStatement<\/span> insertStmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>insertSQL<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token comment\">\/\/ \u5b57\u7b26\u4e32<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;\u7b14\u8bb0\u672c\u7535\u8111&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u6d6e\u70b9\u6570<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setBigDecimal<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">BigDecimal<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;5999.99&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u6574\u6570<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">100<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u5e03\u5c14\u503c<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setBoolean<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">4<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token boolean\">true<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u65e5\u671f\u65f6\u95f4<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setTimestamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">5<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">Timestamp<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">currentTimeMillis<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u957f\u6587\u672c<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setClob<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">6<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\"><span class=\"token namespace\">javax<span class=\"token punctuation\">.<\/span>sql<span class=\"token punctuation\">.<\/span>rowset<span class=\"token punctuation\">.<\/span>serial<span class=\"token punctuation\">.<\/span><\/span>SerialClob<\/span><span class=\"token punctuation\">(<\/span><br \/>\n                <span class=\"token string\">&#034;\u8fd9\u662f\u4e00\u6b3e\u9ad8\u6027\u80fd\u7b14\u8bb0\u672c\u7535\u8111&#8230;&#034;<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">toCharArray<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u4e8c\u8fdb\u5236\u6570\u636e<\/span><br \/>\n            <span class=\"token keyword\">byte<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> metadata <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;{&#039;color&#039;: &#039;silver&#039;, &#039;weight&#039;: &#039;2.5kg&#039;}&#034;<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">getBytes<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setBytes<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">7<\/span><span class=\"token punctuation\">,<\/span> metadata<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ NULL\u503c\u5904\u7406<\/span><br \/>\n            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setNull<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Types<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">INTEGER<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u8bbe\u7f6equantity\u4e3aNULL<\/span><\/p>\n<p>            insertStmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeUpdate<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ 5. \u53ef\u6eda\u52a8\u7684\u7ed3\u679c\u96c6<\/span><br \/>\n        sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT * FROM users ORDER BY id&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span><br \/>\n            sql<span class=\"token punctuation\">,<\/span><br \/>\n            <span class=\"token class-name\">ResultSet<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">TYPE_SCROLL_INSENSITIVE<\/span><span class=\"token punctuation\">,<\/span>  <span class=\"token comment\">\/\/ \u53ef\u6eda\u52a8<\/span><br \/>\n            <span class=\"token class-name\">ResultSet<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">CONCUR_READ_ONLY<\/span>          <span class=\"token comment\">\/\/ \u53ea\u8bfb<\/span><br \/>\n        <span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u79fb\u52a8\u5230\u7ed3\u679c\u96c6\u672b\u5c3e<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">last<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u603b\u8bb0\u5f55\u6570: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getRow<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u79fb\u52a8\u5230\u7b2c\u4e00\u884c<\/span><br \/>\n            rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">first<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u76f8\u5bf9\u79fb\u52a8<\/span><br \/>\n            rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">relative<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">5<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u5411\u524d\u79fb\u52a85\u884c<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u7edd\u5bf9\u79fb\u52a8<\/span><br \/>\n            rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">absolute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">10<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token comment\">\/\/ \u79fb\u52a8\u5230\u7b2c10\u884c<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u79fb\u52a8\u5230\u63d2\u5165\u884c&#xff08;\u7528\u4e8e\u63d2\u5165\u65b0\u8bb0\u5f55&#xff09;<\/span><br \/>\n            <span class=\"token comment\">\/\/ rs.moveToInsertRow();<\/span><br \/>\n            <span class=\"token comment\">\/\/ rs.updateString(&#034;name&#034;, &#034;New User&#034;);<\/span><br \/>\n            <span class=\"token comment\">\/\/ rs.insertRow();<\/span><br \/>\n            <span class=\"token comment\">\/\/ rs.moveToCurrentRow();<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n        rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * \u52a8\u6001SQL\u6784\u5efa&#xff08;\u5b89\u5168\u7684\u53c2\u6570\u5316\u67e5\u8be2&#xff09;<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">Map<\/span><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> <span class=\"token function\">dynamicQuery<\/span><span class=\"token punctuation\">(<\/span><br \/>\n            <span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span><br \/>\n            <span class=\"token class-name\">Map<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> filters<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token class-name\">StringBuilder<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">StringBuilder<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;SELECT * FROM products WHERE 1&#061;1&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> parameters <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">ArrayList<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u52a8\u6001\u6784\u5efaWHERE\u6761\u4ef6<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">containsKey<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;category&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; AND category &#061; ?&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;category&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">containsKey<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;minPrice&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; AND price &gt;&#061; ?&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;minPrice&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">containsKey<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;maxPrice&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; AND price &lt;&#061; ?&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;maxPrice&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">containsKey<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;name&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; AND name LIKE ?&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;%&#034;<\/span> <span class=\"token operator\">&#043;<\/span> filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;name&#034;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034;%&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6392\u5e8f<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">containsKey<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;sortBy&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> sortField <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">)<\/span> filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;sortField&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token comment\">\/\/ \u9632\u6b62SQL\u6ce8\u5165&#xff1a;\u9a8c\u8bc1\u6392\u5e8f\u5b57\u6bb5<\/span><br \/>\n            <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token function\">isValidSortField<\/span><span class=\"token punctuation\">(<\/span>sortField<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; ORDER BY &#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span>sortField<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;DESC&#034;<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">equalsIgnoreCase<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">)<\/span> filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;sortOrder&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; DESC&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u5206\u9875<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">containsKey<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;pageSize&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">append<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034; LIMIT ? OFFSET ?&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">int<\/span> pageSize <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span><span class=\"token punctuation\">)<\/span> filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;pageSize&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">int<\/span> page <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span><span class=\"token punctuation\">)<\/span> filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">getOrDefault<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;page&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>pageSize<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span>page <span class=\"token operator\">&#8211;<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">*<\/span> pageSize<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u6267\u884c\u67e5\u8be2<\/span><br \/>\n        <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">.<\/span><span class=\"token function\">toString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span> i <span class=\"token operator\">&lt;<\/span> parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">size<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setObject<\/span><span class=\"token punctuation\">(<\/span>i <span class=\"token operator\">&#043;<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> parameters<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">Map<\/span><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> results <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">ArrayList<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token class-name\">ResultSetMetaData<\/span> metaData <span class=\"token operator\">&#061;<\/span> rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getMetaData<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">int<\/span> columnCount <span class=\"token operator\">&#061;<\/span> metaData<span class=\"token punctuation\">.<\/span><span class=\"token function\">getColumnCount<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">while<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">Map<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> row <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">HashMap<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span> i <span class=\"token operator\">&lt;&#061;<\/span> columnCount<span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token class-name\">String<\/span> columnName <span class=\"token operator\">&#061;<\/span> metaData<span class=\"token punctuation\">.<\/span><span class=\"token function\">getColumnName<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                row<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span>columnName<span class=\"token punctuation\">,<\/span> rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getObject<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n            results<span class=\"token punctuation\">.<\/span><span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>row<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> results<span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">private<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">boolean<\/span> <span class=\"token function\">isValidSortField<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span> field<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u767d\u540d\u5355\u9a8c\u8bc1<\/span><br \/>\n        <span class=\"token class-name\">Set<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> validFields <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">Set<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">of<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;id&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;name&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;price&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;created_at&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;category&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">return<\/span> validFields<span class=\"token punctuation\">.<\/span><span class=\"token function\">contains<\/span><span class=\"token punctuation\">(<\/span>field<span class=\"token punctuation\">.<\/span><span class=\"token function\">toLowerCase<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * \u5b58\u50a8\u8fc7\u7a0b\u8c03\u7528<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">callStoredProcedure<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token comment\">\/\/ \u8c03\u7528\u65e0\u8fd4\u56de\u503c\u7684\u5b58\u50a8\u8fc7\u7a0b<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> callSQL <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;{call update_user_status(?, ?)}&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">CallableStatement<\/span> cstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareCall<\/span><span class=\"token punctuation\">(<\/span>callSQL<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1001<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;INACTIVE&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u8c03\u7528\u6709\u8fd4\u56de\u503c\u7684\u5b58\u50a8\u8fc7\u7a0b<\/span><br \/>\n        callSQL <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;{? &#061; call calculate_order_total(?)}&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">CallableStatement<\/span> cstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareCall<\/span><span class=\"token punctuation\">(<\/span>callSQL<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">registerOutParameter<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Types<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">DECIMAL<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">5001<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token class-name\">BigDecimal<\/span> total <span class=\"token operator\">&#061;<\/span> cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">getBigDecimal<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u8ba2\u5355\u603b\u989d: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> total<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u8c03\u7528\u6709\u7ed3\u679c\u96c6\u7684\u5b58\u50a8\u8fc7\u7a0b<\/span><br \/>\n        callSQL <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;{call get_user_orders(?)}&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">CallableStatement<\/span> cstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareCall<\/span><span class=\"token punctuation\">(<\/span>callSQL<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1001<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">boolean<\/span> hasResults <span class=\"token operator\">&#061;<\/span> cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">execute<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>hasResults<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> cstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">getResultSet<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token keyword\">while<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u8ba2\u5355: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;order_no&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n                rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/**<br \/>\n     * \u6279\u91cf\u66f4\u65b0\u7684\u6700\u4f73\u5b9e\u8df5<br \/>\n     *\/<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">batchUpdateBestPractice<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn<span class=\"token punctuation\">,<\/span><br \/>\n                                             <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">Map<\/span><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> updates<span class=\"token punctuation\">)<\/span><br \/>\n            <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>        <span class=\"token keyword\">boolean<\/span> originalAutoCommit <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">getAutoCommit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">setAutoCommit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token boolean\">false<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;UPDATE products SET price &#061; ?, stock &#061; ? WHERE id &#061; ?&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token keyword\">int<\/span> batchSize <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Map<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> update <span class=\"token operator\">:<\/span> updates<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setBigDecimal<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">BigDecimal<\/span><span class=\"token punctuation\">)<\/span> update<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;price&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Integer<\/span><span class=\"token punctuation\">)<\/span> update<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;stock&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Integer<\/span><span class=\"token punctuation\">)<\/span> update<span class=\"token punctuation\">.<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;id&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">addBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                batchSize<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>                <span class=\"token comment\">\/\/ \u5b9a\u671f\u6267\u884c\u6279\u5904\u7406&#xff0c;\u907f\u514d\u5185\u5b58\u6ea2\u51fa<\/span><br \/>\n                <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>batchSize <span class=\"token operator\">%<\/span> <span class=\"token number\">1000<\/span> <span class=\"token operator\">&#061;&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                    pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">clearBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u6267\u884c\u5269\u4f59\u7684\u6279\u5904\u7406<\/span><br \/>\n            <span class=\"token keyword\">int<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> updateCounts <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeBatch<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u9a8c\u8bc1\u66f4\u65b0\u7ed3\u679c<\/span><br \/>\n            <span class=\"token keyword\">for<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i <span class=\"token operator\">&#061;<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span> i <span class=\"token operator\">&lt;<\/span> updateCounts<span class=\"token punctuation\">.<\/span>length<span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">&#043;&#043;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>updateCounts<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#061;&#061;<\/span> <span class=\"token class-name\">Statement<\/span><span class=\"token punctuation\">.<\/span><span class=\"token constant\">EXECUTE_FAILED<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>err<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u7b2c &#034;<\/span> <span class=\"token operator\">&#043;<\/span> <span class=\"token punctuation\">(<\/span>i<span class=\"token operator\">&#043;<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034; \u6761\u66f4\u65b0\u5931\u8d25&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                    <span class=\"token comment\">\/\/ \u53ef\u4ee5\u8003\u8651\u8bb0\u5f55\u5931\u8d25\u7684\u6570\u636e\u4ee5\u4fbf\u91cd\u8bd5<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><\/p>\n<p>            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">commit<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">SQLException<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">rollback<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">throw<\/span> e<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">finally<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">setAutoCommit<\/span><span class=\"token punctuation\">(<\/span>originalAutoCommit<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">static<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">main<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">[<\/span><span class=\"token punctuation\">]<\/span> args<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> url <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;jdbc:mysql:\/\/localhost:3306\/testdb&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> user <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;root&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">String<\/span> password <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;password&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token class-name\">Connection<\/span> conn <span class=\"token operator\">&#061;<\/span> <span class=\"token class-name\">DriverManager<\/span><span class=\"token punctuation\">.<\/span><span class=\"token function\">getConnection<\/span><span class=\"token punctuation\">(<\/span>url<span class=\"token punctuation\">,<\/span> user<span class=\"token punctuation\">,<\/span> password<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token function\">demoAdvancedFeatures<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u6d4b\u8bd5\u52a8\u6001\u67e5\u8be2<\/span><br \/>\n            <span class=\"token class-name\">Map<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> filters <span class=\"token operator\">&#061;<\/span> <span class=\"token keyword\">new<\/span> <span class=\"token class-name\">HashMap<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;category&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;electronics&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;minPrice&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1000<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;sortField&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;price&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;sortOrder&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token string\">&#034;DESC&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;pageSize&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">10<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            filters<span class=\"token punctuation\">.<\/span><span class=\"token function\">put<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;page&#034;<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token class-name\">List<\/span><span class=\"token generics\"><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">Map<\/span><span class=\"token punctuation\">&lt;<\/span><span class=\"token class-name\">String<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token class-name\">Object<\/span><span class=\"token punctuation\">&gt;<\/span><span class=\"token punctuation\">&gt;<\/span><\/span> results <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">dynamicQuery<\/span><span class=\"token punctuation\">(<\/span>conn<span class=\"token punctuation\">,<\/span> filters<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u67e5\u8be2\u7ed3\u679c\u6570\u91cf: &#034;<\/span> <span class=\"token operator\">&#043;<\/span> results<span class=\"token punctuation\">.<\/span><span class=\"token function\">size<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">SQLException<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            e<span class=\"token punctuation\">.<\/span><span class=\"token function\">printStackTrace<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<h3>5. \u7efc\u5408\u5bf9\u6bd4\u8868\u683c<\/h3>\n<table>\n<tr>\u7279\u6027StatementPreparedStatement<\/tr>\n<tbody>\n<tr>\n<td>SQL\u6ce8\u5165\u9632\u62a4<\/td>\n<td>\u274c \u4e0d\u5b89\u5168<\/td>\n<td>\u2705 \u5b89\u5168&#xff08;\u53c2\u6570\u5316\u67e5\u8be2&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u6027\u80fd<\/td>\n<td>\u5dee&#xff08;\u6bcf\u6b21\u89e3\u6790SQL&#xff09;<\/td>\n<td>\u597d&#xff08;\u9884\u7f16\u8bd1&#xff0c;\u53ef\u91cd\u7528&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u53ef\u8bfb\u6027<\/td>\n<td>\u5dee&#xff08;\u5b57\u7b26\u4e32\u62fc\u63a5&#xff09;<\/td>\n<td>\u597d&#xff08;\u53c2\u6570\u5360\u4f4d\u7b26&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u6570\u636e\u7c7b\u578b\u5904\u7406<\/td>\n<td>\u624b\u52a8\u8f6c\u4e49<\/td>\n<td>\u81ea\u52a8\u5904\u7406<\/td>\n<\/tr>\n<tr>\n<td>\u6279\u5904\u7406\u652f\u6301<\/td>\n<td>\u6709\u9650<\/td>\n<td>\u4f18\u79c0&#xff08;addBatch\/executeBatch&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u5185\u5b58\u4f7f\u7528<\/td>\n<td>\u9ad8&#xff08;\u91cd\u590d\u89e3\u6790&#xff09;<\/td>\n<td>\u4f4e&#xff08;\u9884\u7f16\u8bd1&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u6570\u636e\u5e93\u7f13\u5b58<\/td>\n<td>\u65e0\u6cd5\u5229\u7528<\/td>\n<td>\u53ef\u5229\u7528\u67e5\u8be2\u7f13\u5b58<\/td>\n<\/tr>\n<tr>\n<td>\u4e8b\u52a1\u5904\u7406<\/td>\n<td>\u76f8\u540c<\/td>\n<td>\u76f8\u540c<\/td>\n<\/tr>\n<tr>\n<td>\u5b58\u50a8\u8fc7\u7a0b\u8c03\u7528<\/td>\n<td>\u4e0d\u652f\u6301<\/td>\n<td>\u652f\u6301&#xff08;CallableStatement&#xff09;<\/td>\n<\/tr>\n<tr>\n<td>\u52a8\u6001SQL<\/td>\n<td>\u5bb9\u6613\u6784\u5efa<\/td>\n<td>\u9700\u8981\u5c0f\u5fc3\u6784\u5efa<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h3>6. \u6700\u4f73\u5b9e\u8df5\u603b\u7ed3<\/h3>\n<li>\u59cb\u7ec8\u4f7f\u7528 PreparedStatement&#xff0c;\u907f\u514dSQL\u6ce8\u5165<\/li>\n<li>\u91cd\u7528 PreparedStatement&#xff0c;\u63d0\u9ad8\u6027\u80fd<\/li>\n<li>\u4f7f\u7528try-with-resources&#xff0c;\u786e\u4fdd\u8d44\u6e90\u91ca\u653e<\/li>\n<li>\u6279\u91cf\u64cd\u4f5c\u65f6\u4f7f\u7528\u4e8b\u52a1&#xff0c;\u63d0\u9ad8\u6548\u7387<\/li>\n<li>\u8bbe\u7f6e\u5408\u9002\u7684fetchSize&#xff0c;\u4f18\u5316\u5927\u6570\u636e\u67e5\u8be2<\/li>\n<li>\u9a8c\u8bc1\u52a8\u6001SQL\u53c2\u6570&#xff0c;\u9632\u6b62SQL\u6ce8\u5165<\/li>\n<li>\u4f7f\u7528\u8fde\u63a5\u6c60&#xff0c;\u7ba1\u7406\u6570\u636e\u5e93\u8fde\u63a5<\/li>\n<li>\u76d1\u63a7SQL\u6267\u884c\u65f6\u95f4&#xff0c;\u4f18\u5316\u6162\u67e5\u8be2<\/li>\n<p><span class=\"token comment\">\/\/ \u6700\u4f73\u5b9e\u8df5\u793a\u4f8b<\/span><br \/>\n<span class=\"token keyword\">public<\/span> <span class=\"token keyword\">class<\/span> <span class=\"token class-name\">BestPracticeExample<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">public<\/span> <span class=\"token keyword\">void<\/span> <span class=\"token function\">queryUsers<\/span><span class=\"token punctuation\">(<\/span><span class=\"token class-name\">DataSource<\/span> dataSource<span class=\"token punctuation\">,<\/span> <span class=\"token keyword\">int<\/span> departmentId<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">throws<\/span> <span class=\"token class-name\">SQLException<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        <span class=\"token class-name\">String<\/span> sql <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;SELECT id, name, email FROM users WHERE department_id &#061; ? AND active &#061; ?&#034;<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>        <span class=\"token comment\">\/\/ \u4f7f\u7528try-with-resources\u81ea\u52a8\u5173\u95ed\u8d44\u6e90<\/span><br \/>\n        <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">Connection<\/span> conn <span class=\"token operator\">&#061;<\/span> dataSource<span class=\"token punctuation\">.<\/span><span class=\"token function\">getConnection<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n             <span class=\"token class-name\">PreparedStatement<\/span> pstmt <span class=\"token operator\">&#061;<\/span> conn<span class=\"token punctuation\">.<\/span><span class=\"token function\">prepareStatement<\/span><span class=\"token punctuation\">(<\/span>sql<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u8bbe\u7f6e\u53c2\u6570<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setInt<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span> departmentId<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setBoolean<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token boolean\">true<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u8bbe\u7f6e\u67e5\u8be2\u8d85\u65f6<\/span><br \/>\n            pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">setQueryTimeout<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">10<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><\/p>\n<p>            <span class=\"token comment\">\/\/ \u6267\u884c\u67e5\u8be2<\/span><br \/>\n            <span class=\"token keyword\">try<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">ResultSet<\/span> rs <span class=\"token operator\">&#061;<\/span> pstmt<span class=\"token punctuation\">.<\/span><span class=\"token function\">executeQuery<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                <span class=\"token keyword\">while<\/span> <span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">next<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n                    <span class=\"token comment\">\/\/ \u5904\u7406\u7ed3\u679c<\/span><br \/>\n                    <span class=\"token class-name\">System<\/span><span class=\"token punctuation\">.<\/span>out<span class=\"token punctuation\">.<\/span><span class=\"token function\">println<\/span><span class=\"token punctuation\">(<\/span>rs<span class=\"token punctuation\">.<\/span><span class=\"token function\">getString<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;name&#034;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n                <span class=\"token punctuation\">}<\/span><br \/>\n            <span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">catch<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token class-name\">SQLException<\/span> e<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n            <span class=\"token comment\">\/\/ \u8bb0\u5f55\u65e5\u5fd7\u5e76\u91cd\u65b0\u629b\u51fa<\/span><br \/>\n            logger<span class=\"token punctuation\">.<\/span><span class=\"token function\">error<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;\u67e5\u8be2\u7528\u6237\u5931\u8d25&#034;<\/span><span class=\"token punctuation\">,<\/span> e<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n            <span class=\"token keyword\">throw<\/span> e<span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>\u9009\u62e9 PreparedStatement \u53ef\u4ee5\u83b7\u5f97\u66f4\u597d\u7684\u5b89\u5168\u6027\u3001\u6027\u80fd\u548c\u53ef\u7ef4\u62a4\u6027\u3002\u53ea\u6709\u5728\u6267\u884c\u52a8\u6001DDL\u8bed\u53e5\u6216\u786e\u5b9e\u9700\u8981\u5b57\u7b26\u4e32\u62fc\u63a5\u7684\u7279\u6b8a\u60c5\u51b5\u4e0b\u624d\u8003\u8651\u4f7f\u7528 Statement\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4<br \/>\n1. \u57fa\u7840\u533a\u522b<br \/>\nimport java.sql.*;public class StatementVsPreparedStatement {public static void main(String[] args) {String url  \\&#8221;jdbc:mysql:\/\/localhost:3306\/testdb\\&#8221;;String user  \\&#8221;root\\&#8221;;String password  \\&#8221;password\\&#8221;<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[99,58,763,427,176],"topic":[],"class_list":["post-62538","post","type-post","status-publish","format-standard","hentry","category-server","tag-java","tag-linux","tag-763","tag-427","tag-176"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/62538.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 1. \u57fa\u7840\u533a\u522b import java.sql.*;public class StatementVsPreparedStatement {public static void main(String[] args) {String url &quot;jdbc:mysql:\/\/localhost:3306\/testdb&quot;;String user &quot;root&quot;;String password &quot;password&quot;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/62538.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2026-01-19T23:49:49+00:00\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"9 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/62538.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/62538.html\",\"name\":\"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2026-01-19T23:49:49+00:00\",\"dateModified\":\"2026-01-19T23:49:49+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/62538.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/62538.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/62538.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/62538.html","og_locale":"zh_CN","og_type":"article","og_title":"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 1. \u57fa\u7840\u533a\u522b import java.sql.*;public class StatementVsPreparedStatement {public static void main(String[] args) {String url \"jdbc:mysql:\/\/localhost:3306\/testdb\";String user \"root\";String password \"password\"","og_url":"https:\/\/www.wsisp.com\/helps\/62538.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2026-01-19T23:49:49+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"9 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/62538.html","url":"https:\/\/www.wsisp.com\/helps\/62538.html","name":"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2026-01-19T23:49:49+00:00","dateModified":"2026-01-19T23:49:49+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/62538.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/62538.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/62538.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"DeepSeek PreparedStatement \u4e0e Statement \u5168\u9762\u5bf9\u6bd4"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/62538","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=62538"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/62538\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=62538"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=62538"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=62538"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=62538"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}