java.sql.SQLException: No value specified for parameter 1 異常分析
錯誤原始碼 java.sql.SQLException: No value specified for parameter 1,因為執行executeQuery()先於對sql語句中的佔位符賦值
@Test
public void test2() {
InputStream is = null;
FileOutputStream fos = null;
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
conn = JDBCUtils.getConnection();
String sql = "select id,name,email,birth,photo from customers where id = ?";
ps = conn.prepareStatement(sql);
// ps.setInt(1,23);
rs = ps.executeQuery();
if (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
String email = rs.getString("email");
Date birth = rs.getDate("birth");
Customers customers = new Customers(id, name, email, birth);
System.out.println(customers);
//將Blob型別的欄位下載下來,以檔案的方式儲存在本地
Blob photo = rs.getBlob("photo");
is = photo.getBinaryStream();
fos = new FileOutputStream("erxiong.jpg");
byte[] buffer = new byte[1024];
int len;
while ((len = is.read(buffer)) != -1) {
fos.write(buffer, 0, len);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (is != null)
is.close();
} catch (IOException e) {
e.printStackTrace();
}
try {
if (fos != null)
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
JDBCUtils.closeResource(conn, ps, rs);
}
}
修改後,執行executeQuery()方法之前,先填寫佔位符
@Test
public void test2() {
InputStream is = null;
FileOutputStream fos = null;
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
conn = JDBCUtils.getConnection();
String sql = "select id,name,email,birth,photo from customers where id = ?";
ps = conn.prepareStatement(sql);
//先對sql佔位符進行賦值
ps.setInt(1,23);
rs = ps.executeQuery();
if (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
String email = rs.getString("email");
Date birth = rs.getDate("birth");
Customers customers = new Customers(id, name, email, birth);
System.out.println(customers);
//將Blob型別的欄位下載下來,以檔案的方式儲存在本地
Blob photo = rs.getBlob("photo");
is = photo.getBinaryStream();
fos = new FileOutputStream("erxiong.jpg");
byte[] buffer = new byte[1024];
int len;
while ((len = is.read(buffer)) != -1) {
fos.write(buffer, 0, len);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (is != null)
is.close();
} catch (IOException e) {
e.printStackTrace();
}
try {
if (fos != null)
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
JDBCUtils.closeResource(conn, ps, rs);
}
}
相關文章
- Idea資料庫引入異常:java.sql.SQLException: The server time zone value ‘Öйú±ê׼ʱ¼ä‘ is unrecognizedIdea資料庫JavaSQLExceptionServerZed
- java.sql.SQLException: Incorrect string valueJavaSQLException
- Flutter 常見異常分析Flutter
- java.sql.SQLException: The server time zone value ‘???ú±ê×??±??‘ is unrecognized or represents moreJavaSQLExceptionServerZed
- 異常處理1
- 異常-try...catch的方式處理異常1
- 異常解決——The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than oneServerZed
- binlog 異常暴漲分析
- java.sql.SQLException: Parameter index out of range (3 > number of parameters, which is 2)的解決方法JavaSQLExceptionIndex
- java.sql.SQLException: The server time zone value ‘Öйú±ê׼ʱ¼ä‘ is unrecognized...報錯解決JavaSQLExceptionServerZed
- ORA-65294: PDB's compatible parameter value (12.2.0.1.0) is higher than CDB's
- 跑批SQL效能異常分析SQL
- bug及異常處理1
- ORA-00837: Specified value of MEMORY_TARGET greater than MEMORY_MAX_TARGET
- wireshark、異常資料分析、常見RST介紹
- 資料庫報錯java.sql.SQLException: Field ‘id‘ doesn‘t have a default value資料庫JavaSQLException
- Linux 常見異常分析,請收好這份排查指南~Linux
- centos 16安裝PHP7.0 異常 No pool defined. at least one pool section must be specified in config fileCentOSPHPAST
- RocketMQ Series---No route info of this topic異常分析MQ
- DRF之異常捕獲原始碼分析原始碼
- [異常等待事件latch undo global data]分析事件
- 「Window平臺」異常掛鉤大法(1)
- 異常和異常呼叫鏈
- 異常篇——異常記錄
- 異常篇——異常處理
- Excel匯入資料異常Cannot get a text value from a numeric cell解決辦法Excel
- 異常-異常的注意事項
- Java 異常(二) 自定義異常Java
- Flutter異常監控 - 貳 | 框架Catcher原理分析Flutter框架
- 故障分析 | 從 data_free 異常說起
- 資料庫異常智慧分析與診斷資料庫
- [異常等待事件rdbms ipc reply]-分析說明事件
- 異常-編譯期異常和執行期異常的區別編譯
- 異常?
- 異常
- 日誌分析(1)常見命令
- Oracle分析函式-first_value()和last_value()Oracle函式AST
- 異常-異常的概述和分類