mysql使用中常用语句记录
提示:以下是本篇文章正文内容,下面案例可供参考
一、insert, replace, insert ignore into,on duplicate key update,insert if not exists
1. insert into 表示插入数据,数据库会检查主键或者唯一索引,若出现重复则会报错
2. replace into 相当于先删除再插入,两条语句合并了
3. insert ignore into 若表中已经存在相同的记录,则忽略当前新数据
4. on duplicate key update 插入记录时,MySQL数据库会首先检索已有数据(idx_username索引),如果存在,则执行update更新操作,如果不存在,则直接插入:
INSERT IGNORE INTO user (username,sex,address) VALUES ('hanpang','boy','HongKong')
on duplicate key update SEX='boy',address='HongKong'
5. insert if not exists
> insert into … select … from dual where not exist ... ,这种方式适合于插入的数据字段没有设置主键或唯一索引
批量更新时,也可以
<insert id="updateSettleForDuplicate">
insert into t_quota_settle
(year,quota_id,settle_amount,settle_price) values
<foreach collection="list" item="item" separator="," >
(#{item.year},#{item.quotaId},#{item.settleAmount},#{item.settlePrice})
</foreach>
ON DUPLICATE KEY UPDATE
year = VALUES(year),quota_id = VALUES(quota_id),settle_amount =
VALUES(settle_amount),settle_price = VALUES(settle_price)
</insert>
批量更新
<insert id="insert" keyColumn="goods_id" keyProperty="goodsId" parameterType="com.shop.test.pojo.entity.test"
useGeneratedKeys="true">
insert into test (shop_id, test_type_id)
values
(#{shopId,jdbcType=BIGINT}, #{goodsTypeId,jdbcType=BIGINT})
</insert>
//先引入
@Resource
private SqlSessionFactory sqlSessionFactory;
//具体实现
SqlSession sqlSession=sqlSessionFactory.openSession(ExecutorType.BATCH);
List<test> insertlist=new ArrayList<>();
test test1=new test((long)1,(long)12);
for(int i=0;i<100000;i++){
insertlist.add(test1);
}
try{
Long mm=System.currentTimeMillis();
TestDao mapper=sqlSession.getMapper(TestDao.class);
insertlist.stream().forEach(e->{
mapper.insert(e);
});
sqlSession.clearCache();
sqlSession.commit();
}catch(Exception e){
System.out.println(e);
}finally{
sqlSession.close();
}
二、base64图像数据可以直接存储为 BLOB
** 存入时应注意编码 txt.getBytes("UTF-8"); 和 new String(base64Img,"UTF-8");
**
然后显示图像
<img src="data:image/jpeg;base64,' . base64_encode($data) . '" />
INSERT语句加where 条件
WHERE 条件 成立就插入
INSERT INTO 表名(字段1,字段2) SELECT 字段1的值,字段2的值
FROM DUAL WHERE EXISTS(SELECT 1 FROM 表名 WHERE 条件)
如:
INSERT INTO user(name,age) SELECT zhangsan,18
FROM DUAL WHERE EXISTS(SELECT 1 FROM user WHERE 1=1)
日期加一天
SELECT DATE_ADD(
MyDate
, INTERVAL 1 DAY) from Add1DayDemo
concat_ws,concat()函数
将多个字符串连接成一个字符串,第一个参数是其它参数的分隔符
CONCAT_WS(separator,str1,str2,…)
总结
提示:数据查询是做关联查询是一定要注意 null 处理
比如:以左表为关联 ,右边没数据,name查询该字段为null
这里碰到个有意思的事:
insert INTO j_study(m_user_id, state, course_year) SELECT ‘6’,‘1’,‘2022’ FROM j_study WHERE not EXISTS(SELECT 1 FROM j_study WHERE m_user_id = 6 )
当我都用FROM j_study 其他表时,始终插入不成功
当:
insert INTO j_study(m_user_id, state, course_year) SELECT ‘6’,‘1’,‘2022’ FROM
dual
WHERE not EXISTS(SELECT 1 FROM j_study WHERE m_user_id = 6 ) 成功