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

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

如何為java預(yù)處理語(yǔ)句插入使用tablename變量

如何為java預(yù)處理語(yǔ)句插入使用tablename變量

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

3 回答

?
倚天杖

TA貢獻(xiàn)1828條經(jīng)驗(yàn) 獲得超3個(gè)贊

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


查看完整回答
反對(duì) 回復(fù) 2019-08-28
?
慕哥9229398

TA貢獻(xiàn)1877條經(jīng)驗(yàn) 獲得超6個(gè)贊

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

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

當(dāng)你知道tablename時(shí)替換

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


查看完整回答
反對(duì) 回復(fù) 2019-08-28
?
慕桂英3389331

TA貢獻(xiàn)2036條經(jīng)驗(yàn) 獲得超8個(gè)贊

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

例如

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


查看完整回答
反對(duì) 回復(fù) 2019-08-28
  • 3 回答
  • 0 關(guān)注
  • 713 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)