sql語句,無法綁定由多個部分組成的標識符 "xxx"
阿新 • • 發佈:2017-09-06
什麽 lec title id字段 數據庫 pan 代碼 今天 esc
String sql = "select TOP 7 news_id,news_title,news_addtime,news_url from web_news_info a" + "LEFT JOIN web_news_small_type b " + "ON a.small_type_id = b.small_type_id " + "LEFT JOIN web_news_big_type c ON a.big_type_id = c.big_type_id " + "WHERE c.big_type_name = ‘新聞公告‘ and b.small_type_name <> ‘新聞‘ and news_view = ‘true‘ ORDER BY is_top DESC, news_addtime DESC";
今天在寫一段sql語句時遇到的問題,上面的代碼放在數據庫中查詢,沒有問題,
但是運行程序的時候突然報了錯,說什麽多個small_type_id字段重復,我不是寫了別名a,b,c嗎。
同事找了幾分鐘把sql打印出來終於找到問題了,a後面少了一個空格,同事提醒我說格式一定要放好,空格要麽在每一行前面加,要麽在每一行後面加,我之前都沒註意到這個,尷尬。
String sql = "select TOP 7 news_id,news_title,news_addtime,news_url from web_news_info a "
+ "LEFT JOIN web_news_small_type b "
+ "ON a.small_type_id = b.small_type_id "
+ "LEFT JOIN web_news_big_type c ON a.big_type_id = c.big_type_id "
+ "WHERE c.big_type_name = ‘新聞公告‘ and b.small_type_name <> ‘新聞‘ and news_view = ‘true‘ ORDER BY is_top DESC, news_addtime DESC";
原因:
1.未給不同的數據表起別名。
2.sql 語句錯誤,可能少了空格,建議將sql語句打印出來檢查。
sql語句,無法綁定由多個部分組成的標識符 "xxx"