Nest.js學(xué)習(xí)之路(20)-TypeORM(7)Query Builder Select(下)

這一章關(guān)于Query Builder會(huì)用的功能做介紹褪那,主要是

  • 分頁(yè)(pagination)
  • select部分屬性
  • 隱藏屬性

分頁(yè)

有三個(gè)變量,建立新的queryUserDTO

import { IsString, IsNumber } from 'class-validator';

export class UserQueryDTO{
    @IsString()
    name: string;

    @IsNumber()
    page: number;

    @IsNumber()
    pageSize: number;
}

新增getUsersByRoleName在user.service.ts

async getUsersByRoleName(query: UserQueryDTO){
        return await this.userRepo
            .createQueryBuilder('u')
            .leftJoinAndSelect('u.roles', 'r')
            .leftJoinAndSelect('u.plat', 'p')
            // 以roleName作為篩選條件
            .where('r.roleName like :name', { name: `%${query.name.toLowerCase()}%`})
            .orderBy('u.name', 'ASC')
            // Orderby也可以串連
            .addOrderBy('u.age')
            // 跳過(guò)數(shù)量师坎,第一頁(yè)就為0,第二頁(yè)跳過(guò)pageSize
            .skip((query.page - 1) * query.pageSize)
            .take(query.pageSize) // 取pageSize筆數(shù)
            .getManyAndCount(); // 回傳record 并 count數(shù)量
    }

使用Postman測(cè)試


2018111407.png

select部分屬性

有時(shí)候不想expose所有屬性堪滨,可以用select來(lái)篩選胯陋,當(dāng)然也有object mapping的套件把部分屬性mapping到新的class上,但先就選擇部分屬性為例袱箱,假設(shè)只想要name, 及roleName遏乔,其他如plat則不需要

async getUsersByRoleName(query: UserQueryDTO){
        return await this.userRepo
            .createQueryBuilder('u')
            .leftJoinAndSelect('u.roles', 'r')
            .leftJoinAndSelect('u.plat', 'p')
            // 以roleName作為篩選條件
            .where('r.roleName like :name', { name: `%${query.name.toLowerCase()}%`})
            .orderBy('u.name', 'ASC')
            // Orderby也可以串連
            .addOrderBy('u.age')
            // 跳過(guò)數(shù)量,第一頁(yè)就為0发笔,第二頁(yè)跳過(guò)pageSize
            .skip((query.page - 1) * query.pageSize)
            .take(query.pageSize) // 取pageSize
            .select([ // 第一直覺(jué)只要列舉要的屬性
                'u.age',
                'u.name',
                'r.id',
                'r.roleName',
            ])
            .getManyAndCount(); // 回傳record 并 count數(shù)量
    }

使用postman測(cè)試


2018111408.png

原因是沒(méi)有SELECT u.id盟萨,這里TypeORM并不會(huì)自動(dòng)產(chǎn)生,但沒(méi)有了讨,所以要自己加捻激,或是直接select alias

在select加上u.id

.select([ 
  'u.id',
  'u.age',
  'u.name',
  'r.id',
  'r.roleName',
])

使用postman測(cè)試


2018111409.png

隱藏屬性

如果有一個(gè)屬性在大多數(shù)時(shí)候都不希望被select到,只有少數(shù)情況會(huì)用到前计,typeorm提供隱藏屬性的概念胞谭,在QueryBuilder中select entity或是Repository find預(yù)設(shè)不會(huì)被選到,則需要在屬性上設(shè)定男杈,如User Entity的password屬性

在user.entity下新增password屬性

@Column({
        nullable: true, // 因?yàn)榇藢傩院髞?lái)才加丈屹,不設(shè)置nullable無(wú)法新增此屬性
        length: 100,
        // 一般用repository.find不會(huì)出現(xiàn)此屬性
        // 在QueryBuilder中select entity也不會(huì)出現(xiàn)
        select: false,
    })
    password: string;

用postman測(cè)試,會(huì)發(fā)現(xiàn)所有返回的用戶(hù)都沒(méi)有帶password屬性

那如何在query的時(shí)候讓password出現(xiàn)呢

修改query伶棒, 新增addSelect讓password出現(xiàn)

.addSelect('u.password')

使用postman測(cè)試


2018111410.png

密碼屬性出現(xiàn)

推薦一下我的公眾號(hào): 【 geekjc 】旺垒,微信號(hào): 【 c8706288 】一起學(xué)習(xí)交流編程知識(shí)彩库,分享經(jīng)驗(yàn),各種有趣的事先蒋。

tuiguang.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末骇钦,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子竞漾,更是在濱河造成了極大的恐慌司忱,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件畴蹭,死亡現(xiàn)場(chǎng)離奇詭異坦仍,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)叨襟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)繁扎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人糊闽,你說(shuō)我怎么就攤上這事梳玫。” “怎么了右犹?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵提澎,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我念链,道長(zhǎng)盼忌,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任掂墓,我火速辦了婚禮谦纱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘君编。我一直安慰自己跨嘉,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布吃嘿。 她就那樣靜靜地躺著祠乃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪兑燥。 梳的紋絲不亂的頭發(fā)上亮瓷,一...
    開(kāi)封第一講書(shū)人閱讀 51,692評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音贪嫂,去河邊找鬼寺庄。 笑死艾蓝,一個(gè)胖子當(dāng)著我的面吹牛力崇,可吹牛的內(nèi)容都是我干的斗塘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼亮靴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼馍盟!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起茧吊,我...
    開(kāi)封第一講書(shū)人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤贞岭,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后搓侄,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體瞄桨,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年讶踪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了芯侥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乳讥,死狀恐怖柱查,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情云石,我是刑警寧澤唉工,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站汹忠,受9級(jí)特大地震影響淋硝,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜宽菜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一奖地、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赋焕,春花似錦参歹、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至侨嘀,卻和暖如春臭挽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背咬腕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工欢峰, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓纽帖,卻偏偏與公主長(zhǎng)得像宠漩,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子懊直,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,811評(píng)論 0 11
  • 這部分主要是開(kāi)源Java EE框架方面的內(nèi)容扒吁,包括Hibernate、MyBatis室囊、Spring雕崩、Spring ...
    雜貨鋪老板閱讀 1,385評(píng)論 0 2
  • CloudJavaBackendSummaries1、開(kāi)發(fā)環(huán)境eclipse工程融撞,引入jw倉(cāng)庫(kù)的jw-base盼铁,3...
    燕京博士閱讀 1,036評(píng)論 0 0
  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL尝偎、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的...
    笨鳥(niǎo)慢飛閱讀 5,523評(píng)論 0 4
  • width: 65%;border: 1px solid #ddd;outline: 1300px solid #...
    邵勝奧閱讀 4,823評(píng)論 0 1