文章詳情頁
MySQL的check約束中可以包含子查詢嗎
瀏覽:88日期:2022-06-21 09:44:00
問題描述
我寫了一句SQL如下:
create table if not exists Teachings( teacher varchar(255), classid varchar(32) references Class(id) check(teacher in (select username from Users where role = ’teacher’)));
但是在執行的時候報錯(MySQL版本5.6.30):
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ’check(teacher in (select username from Users where role = ’teacher’)))’ at line 4
是不是MySQL中的check約束不能包含子查詢呢?如果是,我的這句SQL應該怎么實現呢?
PS:完整的SQL見這里
問題解答
回答1:DDL漏了個逗號
MySQL并不支持CHECK約束,參見MySQL文檔
可以用觸發器來實現
相關文章:
1. javascript - axios請求回來的數據組件無法進行綁定渲染2. javascript - main head .intro-text{width:40%} main head{display:flex}為何無效?3. java - 在用戶不登錄的情況下,用戶如何添加保存到購物車?4. javascript - JS變量被清空5. javascript - jQuery post()方法,里面的請求串可以轉換為GBK編碼么?可以的話怎樣轉換?6. Python中使用超長的List導致內存占用過大7. css3 - 純css實現點擊特效8. 安全性測試 - nodejs中如何防mySQL注入9. javascript - 關于apply()與call()的問題10. javascript - 有適合開發手機端Html5網頁小游戲的前端框架嗎?
排行榜
