jpa操作數(shù)據(jù)庫問題總結(jié)

一、jpa批量新增數(shù)據(jù)

saveAll()方法不可取采呐,看下源碼就知道其原理是 for 循環(huán)每一條數(shù)據(jù),然后先select一次搁骑,如果數(shù)據(jù)庫存在斧吐,則update。如果不存在仲器,則insert煤率。
相關(guān)源碼如下:

    @Transactional
    public <S extends T> List<S> saveAll(Iterable<S> entities) {

        Assert.notNull(entities, "Entities must not be null!");

        List<S> result = new ArrayList<S>();

        for (S entity : entities) {
            result.add(save(entity));
        }

        return result;
    }

    @Transactional
    public <S extends T> S save(S entity) {

        if (entityInformation.isNew(entity)) {
            em.persist(entity);
            return entity;
        } else {
            return em.merge(entity);
        }
    }

解決方法:只基于jpa作優(yōu)化,jdbc乏冀、mybatis不在討論范圍之內(nèi)(原生SQL大法好)

    @PersistenceContext
    private EntityManager entityManager;

    @Override
    @Transactional
    public void addBatch(List<ProjectApplyDO> list) {
        for (ProjectApplyDO projectApplyDO : list) {
            entityManager.persist(projectApplyDO);
        }
        entityManager.flush();
        entityManager.clear();
    }

二蝶糯、jpa分頁查詢

非原生SQL(條件包含字符串、日期類型)例子如下:

    public Page<ProjectApplyDO> findAll(ProjectApplyDO projectApplyDO, PageDO pageDO) {
        Sort sort = new Sort(Sort.Direction.DESC, "id");
        // 分頁從0開始
        Pageable pageable = PageRequest.of(pageDO.getCurrent() - 1, pageDO.getSize(), sort);

        return projectApplyDao.findAll((Specification<ProjectApplyDO>) (root, query, builder) -> {
            Predicate predicate = builder.conjunction();
            List<Expression<Boolean>> list = predicate.getExpressions();
            if (projectApplyDO.getUuid() != null) {
                list.add(builder.equal(root.get("uuid"), projectApplyDO.getUuid()));
            }
            if (projectApplyDO.getProjectName() != null) {
                list.add(builder.like(root.get("projectName"), "%" + projectApplyDO.getProjectName() + "%"));
            }
            if (projectApplyDO.getApplyStartDate() != null) {
                list.add(builder.greaterThan(root.get("applyStartDate"), projectApplyDO.getApplyStartDate()));
            }
            if (projectApplyDO.getApplyEndDate() != null) {
                list.add(builder.lessThan(root.get("applyEndDate"), projectApplyDO.getApplyEndDate()));
            }
            return predicate;
        }, pageable);
    }

三辆沦、原生SQL增刪改查

  1. 使用 EntityManager 實現(xiàn)增刪改查昼捍,應(yīng)該是學(xué)習(xí)成本最低的一種方式。
    @PersistenceContext
    private EntityManager entityManager;

    public List<ProjectApplyDO> findAll(ProjectApplyDO projectApplyDO, PageDO pageDO) {
        // 字符串任意拼接
        String sql = ...
        Query sql = entityManager.createNativeQuery(sql, ProjectApplyDO.class);
        return sql.getResultList();
    }
  1. 使用注解 @Query

2.1众辨、參數(shù)為 Entity 對象端三,語法比較古怪

@Modifying
@Query(value = "insert into cms_system_notice (content, start_date, end_date, create_user) values (:#{#notice.content}, :#{#notice.startDate}, :#{#notice.endDate}, :#{#notice.createUser})", nativeQuery = true)
void insert(@Param("notice") SystemNoticeDO systemNoticeDO);

2.2、參數(shù)為基本類型

@Modifying
@Query(value = "update cms_system_notice set status = :status where id = :id", nativeQuery = true)
void updateStatus(@Param("id") int id, @Param("status") int status);

用mybatis鹃彻,基于注解開發(fā)郊闯,也沒什么配置,只需要會原生SQL蛛株,就可以上手了团赁。
相比之下,jpa麻煩多了谨履,還涉及一些SQL優(yōu)化欢摄,控制臺打印SQL因為表名別名原因,也不簡潔美觀笋粟。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
禁止轉(zhuǎn)載怀挠,如需轉(zhuǎn)載請通過簡信或評論聯(lián)系作者析蝴。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市绿淋,隨后出現(xiàn)的幾起案子闷畸,更是在濱河造成了極大的恐慌,老刑警劉巖吞滞,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件佑菩,死亡現(xiàn)場離奇詭異,居然都是意外死亡裁赠,警方通過查閱死者的電腦和手機殿漠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來佩捞,“玉大人绞幌,你說我怎么就攤上這事∈Ъ猓” “怎么了啊奄?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長掀潮。 經(jīng)常有香客問我菇夸,道長,這世上最難降的妖魔是什么仪吧? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任庄新,我火速辦了婚禮,結(jié)果婚禮上薯鼠,老公的妹妹穿的比我還像新娘择诈。我一直安慰自己,他們只是感情好出皇,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布羞芍。 她就那樣靜靜地躺著,像睡著了一般郊艘。 火紅的嫁衣襯著肌膚如雪荷科。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天纱注,我揣著相機與錄音畏浆,去河邊找鬼。 笑死狞贱,一個胖子當著我的面吹牛刻获,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播瞎嬉,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蝎毡,長吁一口氣:“原來是場噩夢啊……” “哼厚柳!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起顶掉,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤草娜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后痒筒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡茬贵,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年簿透,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片解藻。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡老充,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出螟左,到底是詐尸還是另有隱情啡浊,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布胶背,位于F島的核電站巷嚣,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏钳吟。R本人自食惡果不足惜廷粒,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望红且。 院中可真熱鬧坝茎,春花似錦、人聲如沸暇番。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽壁酬。三九已至次酌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間厨喂,已是汗流浹背和措。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留蜕煌,地道東北人派阱。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像斜纪,于是被迫代替她去往敵國和親贫母。 傳聞我的和親對象是個殘疾皇子文兑,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353