常用SQL语句和HQL语句写法
1、左(右)外連接:
select b.phone_no,a.pak_no from t_phone a left(right) join t_pak_used b on (a.phone_no=b.phone_no) where a.phone_num = '13045977553'
--------------------------------------------------------------------------------------------------------------------------------------------------
2、外連接:
select b.phone_no,a.pak_no from t_phone a join t_pak_used b on (a.phone_no=b.phone_no) where a.phone_num = '13045977553'
--------------------------------------------------------------------------------------------------------------------------------------------------
3、SQL中類似JAVA的 switch-case語句:
SELECT <myColumnSpec> = CASE
WHEN <A> THEN <somethingA>
WHEN <B> THEN <somethingB>
ELSE <somethingE>
END
--------------------------------------------------------------------------------------------------------------------------------------------------
3、在mybatis中如果傳遞多個參數,參數值類型parameterType可以不寫,然后SQL語句:
update t_pak_used set sp_call = #{0} where phone_no = #{1} //傳遞參數的順序必須正確
--------------------------------------------------------------------------------------------------------------------------------------------------
4、mybatis中forEach的用法:
<select id="" parameterType="list">
select * from G_Dept where a in
<foreach collection="list" item="i" open="(" separator="," close=")" >
#{i} //等價于(#{i1},#{i2},#{i3}...)
</foreach>
</select>
--------------------------------------------------------------------------------------------------------------------------------------------------
5、oracle中的分頁查詢語句:
//此語句查詢出第11到第60條數據,rowno為rownum的別名
select * from (select rownum rowno, t.* from t_phone t where rownum <= 60) where rowno >10
--------------------------------------------------------------------------------------------------------------------------------------------------
6、MySQL中的分頁查詢語句:
select * from table_name limit 10,5 //取第11到15條數據,后一個參數代表返回行的最大數目
--------------------------------------------------------------------------------------------------------------------------------------------------
7、oracle中隨機獲取20條數據:
select * from(select * from t_phone order by dbms_random.value) where rownum <=20;
--------------------------------------------------------------------------------------------------------------------------------------------------
==================================================================================================================================================
==================================================================================================================================================
********HQL語句********
1、查詢:
這里需要注意的是,from后面跟的不是表名而是實體類名,如果要查找所有select后不跟*,而是跟類名的別名
String hql = "select user from UserBean user";
查找后放入集合中:
Query query = session.createQuery(hql);
List<UserBean> user = query.list();
如果要查找個別字段:
String hql = "select user.userName form UserBean user";
**如果查詢多個字段,則返回的是個Object[],可使用以下方法取得數值:
for(int i = 0; i<user.size(); i++){
Object [] a = (Object[]) user.get(i);
}
**查詢中也可以使用?來占位,參數的索引一樣從0開始:
String hql = "select user from UserBean user where user.userName like ?";
Query query = session.createQuery(hql);
query.setParameter(0, "peter");
--------------------------------------------------------------------------------------------------------------------------------------------------
2、插入增加:
直接調用Hibernate中save()方法:
UserBean user = new UserBean();
session.save(user);
--------------------------------------------------------------------------------------------------------------------------------------------------
3、修改:
update后面跟的是實體類名,注意要executeUpdate()
String hql = "update UserBean user set user.id=10 where user.id=5";
Query query = session.createQuery(hql);
int ret = query.executeUpdate();
--------------------------------------------------------------------------------------------------------------------------------------------------
4、刪除:
這里需要注意的是from后是實體類名
String hql = " DELETE FROM UserBean user WHERE user.id = 1 ";
Query queryupdate = session.createQuery(hql);
int ret = queryupdate.executeUpdate();
--------------------------------------------------------------------------------------------------------------------------------------------------
?
轉載于:https://www.cnblogs.com/monkey200804/p/7140589.html
總結
以上是生活随笔為你收集整理的常用SQL语句和HQL语句写法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: InnoDB: Error: log f
- 下一篇: TOMCAT配置管理员