第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何為java預處理語句插入使用tablename變量

如何為java預處理語句插入使用tablename變量

慕虎7371278 2019-08-28 09:10:44
如何為java預處理語句插入使用tablename變量我正在使用java PreparedStatment對象來構(gòu)造一系列批量INSERT查詢。查詢語句的格式是......String strQuery = "INSERT INTO ? (col1, col2, col3, col4, col5) VALUES (?,?,?,?,?,?);";...所以字段值和表名都是變量(即,我有多個具有相同列格式的表,其中每個插入將指向不同的一個)。如果我刪除“?”,我可以讓執(zhí)行工作 tablename變量和硬代碼,但每個預處理語句將被插入到不同的表中,因此需要保留一個變量,我在執(zhí)行批處理查詢之前立即填充...stmt.setString(1, "tableName1");我怎么能讓這個變成動態(tài)變量呢?
查看完整描述

3 回答

?
倚天杖

TA貢獻1828條經(jīng)驗 獲得超3個贊

你不能。您需要使用字符串連接/占位符和String.format構(gòu)造sql。prepared語句用于列值而不是表名。


查看完整回答
反對 回復 2019-08-28
?
慕哥9229398

TA貢獻1877條經(jīng)驗 獲得超6個贊

您可以使用占位符代替表名,然后將其替換為您的表名。

String strQuery = "INSERT INTO $tableName (col1, col2, col3, col4, col5)
             VALUES (?,?,?,?,?,?);";

當你知道tablename時替換

String query =strQuery.replace("$tableName",tableName);stmt =conn.prepareStatement(query);


查看完整回答
反對 回復 2019-08-28
?
慕桂英3389331

TA貢獻2036條經(jīng)驗 獲得超8個贊

一種替代方案可能是String.format

例如

String sql = String.format("INSERT INTO $1%s (col1, col2, col3, (etc)",  myTablename);


查看完整回答
反對 回復 2019-08-28
  • 3 回答
  • 0 關注
  • 704 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號