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 ) 成功

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值