1. 程式人生 > >sql語句,無法綁定由多個部分組成的標識符 "xxx"

sql語句,無法綁定由多個部分組成的標識符 "xxx"

什麽 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"