主頁 > 後端開發 > mongodb還不會?萬字長文決議揉碎了給你講,收藏這一篇就夠了

mongodb還不會?萬字長文決議揉碎了給你講,收藏這一篇就夠了

2021-07-31 08:17:56 後端開發

大家好,我是辣條,

目錄

Mongodb的的增刪改查

1. mongodb插入資料

2. mongodb的保存

3 mongodb的查詢

4 mongodb的更新

5 mongodb的洗掉

mongodb的聚合操作

1 mongodb的聚合是什么

2 mongodb的常用管道和運算式

3 管道命令之$group

4 管道命令之$match

5 管道命令之$project

6 管道命令之$sort

7 管道命令之$skip 和 $limit

1. 為什么mongdb需要創建索引

2. mongodb創建簡單的索引方法

3. 創建索引前后查詢速度對比

4. 索引的查看

5. 洗掉索引

6. mongodb創建唯一索引

7. 建立復合索引

8. 建立索引注意點

Mongodb的權限管理

1. 為什么要進行權限管理的設定

2. mongodb的權限管理方案

3. mongodb超級管理員賬號的創建

4. 創建普通用戶

5. 查看創建的用戶

6. 洗掉用戶

mongodb和python互動

1. mongdb和python互動的模塊

2. 使用pymongo

3. pymongo模塊其他api


Mongodb的的增刪改查

1. mongodb插入資料

命令:db.集合名稱.insert(document)

db.stu.insert({name:'gj', gender:1})
db.stu.insert({_id:"20170101", name:'gj', gender:1})

插檔案時,如果不指定_id引數,MongoDB會為檔案自動分配一個唯一的ObjectId

2. mongodb的保存

命令:db.集合名稱.save(document)

db.stu.save({_id:'20170101', name:'gj', gender:2})
db.stu.save({name:'gj', gender:2})
db.stu.find()

如果檔案的id已經存在則修改,如果id不存在則添加

3 mongodb的查詢

命令:db.集合名稱.find()

可以使用以下資料進行練習

db.stu.insert([{"name" : "郭靖", "hometown" : "蒙古", "age" : 20, "gender" : true },
{"name" : "黃蓉", "hometown" : "桃花島", "age" : 18, "gender" : false },
{"name" : "華箏", "hometown" : "蒙古", "age" : 18, "gender" : false },
{"name" : "黃藥師", "hometown" : "桃花島", "age" : 40, "gender" : true },
{"name" : "段譽", "hometown" : "大理", "age" : 16, "gender" : true },
{"name" : "段王爺", "hometown" : "大理", "age" : 45, "gender" : true },
{"name" : "洪七公", "hometown" : "華箏", "age" : 18, "gender" : true }])

3.1 簡單查詢

  • 方法find(): 查詢

    db.集合名稱.find({條件檔案})

  • 方法findOne():查詢,只回傳第一個

    db.集合名稱.findOne({條件檔案})

  • 方法pretty(): 將結果格式化;不能和findOne()一起使用!

    db.集合名稱.find({條件檔案}).pretty()

3.2 比較運算子

  • 等于: 默認是等于判斷, 沒有運算子

  • 小于:$lt (less than)

  • 小于等于:$lte (less than equal)

  • 大于:$gt (greater than)

  • 大于等于:$gte

  • 不等于:$ne

查詢年齡大于18的所有學生
db.stu.find({age:{$gte:18}})

3.3 邏輯運算子

邏輯運算子主要指與、或邏輯

  • and:在json中寫多個條件即可

查詢年齡大于或等于18, 并且性別為true的學生
db.stu.find({age:{$gte:18},gender:true})
  • or:使用$or, 值為陣列, 陣列中每個元素為json

查詢年齡大于18, 或性別為false的學生
db.stu.find({$or:[{age:{$gt:18}},{gender:false}]})
?
查詢年齡大于18或性別為男生, 并且姓名是郭靖
db.stu.find({$or:[{age:{$gte:18}},{gender:true}],name:'gj'})

3.4 范圍運算子

使用$in$nin 判斷資料是否在某個陣列內

查詢年齡為18、 28的學生
db.stu.find({age:{$in:[18,28,38]}})

3.5 支持正則運算式

使用$regex撰寫正則運算式

查詢name以'黃'開頭的資料
db.stu.find({name:{$regex:'^黃'}})

3.6 自定義查詢

mongo shell 是一個js的執行環境 使用$where 寫一個函式, 回傳滿足條件的資料

查詢年齡大于30的學生
db.stu.find({
 $where:function() {
     return this.age>30;}
})

3.7 skip和limit

  • 方法limit(): 用于讀取指定數量的檔案

db.集合名稱.find().limit(NUMBER)
查詢2條學生資訊
db.stu.find().limit(2)
  • 方法skip(): 用于跳過指定數量的?檔

db.集合名稱.find().skip(NUMBER)
db.stu.find().skip(2)
  • 同時使用

db.stu.find().limit(4).skip(5)
db.stu.find().skip(5).limit(4)

注意:先使用skip在使用limit的效率要高于前者

3.8 投影

在查詢到的回傳結果中, 只選擇必要的欄位

命令:db.集合名稱.find({},{欄位名稱:1,...})

引數為欄位與值, 值為1表示顯示, 值為0不顯 特別注意:

  • 對于_id列默認是顯示的, 如果不顯示需要明確設定為0

  • 對于其他不顯示的欄位不能設定為0

db.stu.find({},{_id:0,name:1,gender:1})

3.9 排序

方法sort(), 用于對查詢結果按照指定的欄位進行排序

命令:db.集合名稱.find().sort({欄位:1,...})

引數1為升序排列 引數-1為降序排列

根據性別降序, 再根據年齡升序
db.stu.find().sort({gender:-1,age:1})

3.10 統計個數

方法count()用于統計結果集中檔案條數

命令:db.集合名稱.find({條件}).count() 命令:db.集合名稱.count({條件})

db.stu.find({gender:true}).count()
db.stu.count({age:{$gt:20},gender:true})

4 mongodb的更新

db.集合名稱.update({query}, {update}, {multi: boolean})
  • 引數query:查詢條件

  • 引數update:更新運算子

  • 引數multi:可選,默認是false,表示只更新找到的第一條資料,值為true表示把滿足條件的資料全部更新

db.stu.update({name:'hr'},{name:'mnc'})           # 全檔案進行覆寫更新
db.stu.update({name:'hr'},{$set:{name:'hys'}})    # 指定鍵值更新操作
db.stu.update({},{$set:{gender:0}},{multi:true})  # 更新全部

注意:"multi update only works with $ operators"

  • multi引數必須和$set一起使用!

5 mongodb的洗掉

db.集合名稱.remove({query}, {justOne: boolean})
- 引數query:可選,洗掉的?檔的條件
- 引數justOne:可選, 如果設為true或1,則只洗掉一條,默認false,表示洗掉全部

mongodb的聚合操作

1 mongodb的聚合是什么

聚合(aggregate)是基于資料處理的聚合管道,每個檔案通過一個由多個階段(stage)組成的管道,可以對每個階段的管道進行分組、過濾等功能,然后經過一系列的處理,輸出相應的結果,

語法:db.集合名稱.aggregate({管道:{運算式}})

2 mongodb的常用管道和運算式

知識點:

  • 掌握mongodb中管道的語法

  • 掌握mongodb中管道命令

2.1 常用管道命令

在mongodb中,?檔處理完畢后, 通過管道進?下?次處理 常用管道命令如下:

  • $group: 將集合中的?檔分組, 可?于統計結果

  • $match: 過濾資料, 只輸出符合條件的?檔

  • $project: 修改輸??檔的結構, 如重命名、 增加、 洗掉欄位、 創建計算結果

  • $sort: 將輸??檔排序后輸出

  • $limit: 限制聚合管道回傳的?檔數

  • $skip: 跳過指定數量的?檔, 并回傳余下的?檔

2.2 常用運算式

運算式:處理輸??檔并輸出 語法:運算式:'$列名' 常?運算式:

  • $sum: 計算總和, $sum:1 表示以?倍計數

  • $avg: 計算平均值

  • $min: 獲取最?值

  • $max: 獲取最?值

  • $push: 在結果?檔中插?值到?個陣列中

3 管道命令之$group

3.1 按照某個欄位進行分組

$group是所有聚合命令中用的最多的一個命令,用來將集合中的檔案分組,可用于統計結果

使用示例如下

db.stu.aggregate(
    {$group:
        {
            _id:"$gender",
            counter:{$sum:1}
        }
    }
)

其中注意點:

  • db.db_name.aggregate是語法,所有的管道命令都需要寫在其中

  • _id 表示分組的依據,按照哪個欄位進行分組,需要使用$gender表示選擇這個欄位進行分組

  • $sum:1 表示把每條資料作為1進行統計,統計的是該分組下面資料的條數

3.2 group by null

當我們需要統計整個檔案的時候,$group 的另一種用途就是把整個檔案分為一組進行統計

使用實體如下:

db.stu.aggregate(
    {$group:
        {
            _id:null,
            counter:{$sum:1}
        }
    }
)

其中注意點:

  • _id:null 表示不指定分組的欄位,即統計整個檔案,此時獲取的counter表示整個檔案的個數

3.3 資料透視

正常情況在統計的不同性別的資料的時候,需要知道所有的name,需要逐條觀察,如果通過某種方式把所有的name放到一起,那么此時就可以理解為資料透視

使用示例如下:

  1. 統計不同性別的學生

    db.stu.aggregate(
        {$group:
            {
                _id:null,
                name:{$push:"$name"}
            }
        }
    )
  2. 使用$$ROOT可以將整個檔案放入陣列中

    db.stu.aggregate(
        {$group:
            {
                _id:null,
                name:{$push:"$$ROOT"}
            }
        }
    )

3.4 動手

對于如下資料,需要統計出每個country/province下的userid的數量(同一個userid只統計一次)

{ "country" : "china", "province" : "sh", "userid" : "a" }  
{  "country" : "china", "province" : "sh", "userid" : "b" }  
{  "country" : "china", "province" : "sh", "userid" : "a" }  
{  "country" : "china", "province" : "sh", "userid" : "c" }  
{  "country" : "china", "province" : "bj", "userid" : "da" }  
{  "country" : "china", "province" : "bj", "userid" : "fa" }

參考答案

db.tv3.aggregate(
  {$group:{_id:{country:'$country',province:'$province',userid:'$userid'}}},
  {$group:{_id:{country:'$_id.country',province:'$_id.province'},count:{$sum:1}}}
?

4 管道命令之$match

$match用于進行資料的過濾,是在能夠在聚合操作中使用的命令,和find區別在于$match 操作可以把結果交給下一個管道處理,而find不行

5 管道命令之$project

$project用于修改檔案的輸入輸出結構,例如重命名,增加,洗掉欄位

6 管道命令之$sort

$sort用于將輸入的檔案排序后輸出

7 管道命令之$skip$limit

  • $limit限制回傳資料的條數

  • $skip 跳過指定的檔案數,并回傳剩下的檔案數

  • 同時使用時先使用skip在使用limit

1. 為什么mongdb需要創建索引

  • 加快查詢速度

  • 進行資料的去重

2. mongodb創建簡單的索引方法

  • 語法:db.集合名.ensureIndex({屬性:1}),1表示升序, -1表示降序

3. 創建索引前后查詢速度對比

測驗:插入10萬條資料到資料庫中

插入資料:

for(i=0;i<100000;i++){db.t1.insert({name:'test'+i,age:i})}

創建索引前:

db.t1.find({name:'test10000'})
db.t1.find({name:'test10000'}).explain('executionStats') # 顯示查詢操作的詳細資訊

創建索引:

db.t1.ensureIndex({name:1})

創建索引后:

db.t1.find({name:'test10000'}).explain('executionStats')

前后速度對比

4. 索引的查看

默認情況下_id是集合的索引 查看方式:db.集合名.getIndexes()

5. 洗掉索引

語法:db.集合名.dropIndex({'索引名稱':1})

db.t1.dropIndex({name:1})
db.t1.getIndexes()

6. mongodb創建唯一索引

在默認情況下mongdb的索引域的值是可以相同的,創建唯一索引之后,資料庫會在插入資料的時候檢查創建索引域的值是否存在,如果存在則不會插入該條資料,但是創建索引僅僅能夠提高查詢速度,同時降低資料庫的插入速度,

6.1 添加唯一索引的語法:

db.集合名.ensureIndex({"欄位名":1}, {"unique":true})

6.2 利用唯一索引進行資料去重

根據唯一索引指定的欄位的值,如果相同,則無法插入資料

db.t1.ensureIndex({"name":1}, {"unique":true})
db.t1.insert({name: 'test10000'})

7. 建立復合索引

在進行資料去重的時候,可能用一個域來保證資料的唯一性,這個時候可以考慮建立復合索引來實作,

例如:抓全貼吧資訊,如果把帖子的名字作為唯一索引對資料進行去重是不可取的,因為可能有很多帖子名字相同

建立復合索引的語法:db.collection_name.ensureIndex({欄位1:1,欄位2:1})

8. 建立索引注意點

  • 根據需要選擇是否需要建立唯一索引

  • 索引欄位是升序還是降序在單個索引的情況下不影響查詢效率,但是帶復合索引的條件下會有影響

  • 資料量巨大并且資料庫的讀出操作非常頻繁的時候才需要創建索引,如果寫入操作非常頻繁,創建索引會影響寫入速度

    例如:在進行查詢的時候如果欄位1需要升序的方式排序輸出,欄位2需要降序的方式排序輸出,那么此時復合索引的建立需要把欄位1設定為1,欄位2設定為-1

Mongodb的權限管理

1. 為什么要進行權限管理的設定

剛安裝完畢的mongodb默認不使用權限認證方式啟動,與MySQL不同,mongodb在安裝的時候并沒有設定權限,然而公網運行系統需要設定權限以保證資料安全,所以我們要學習mongodb的權限管理

2. mongodb的權限管理方案

  • MongoDB是沒有默認管理員賬號,所以要先添加管理員賬號,并且mongodb服務器需要在運行的時候開啟驗證模式

    • 用戶只能在用戶所在資料庫登錄(創建用戶的資料庫),包括管理員賬號,

    • 管理員可以管理所有資料庫,但是不能直接管理其他資料庫,要先認證后才可以,

3. mongodb超級管理員賬號的創建

3.1 創建超級用戶

進入mongo shell

sudo mongod

使用admin資料庫(超級管理員賬號必須創建在該資料庫上)

use admin

創建超級用戶

db.createUser({"user":"python","pwd":"python","roles":["root"]})

創建成功會顯示如下資訊

Successfully added user: { "user" : "python", "roles" : [ "root" ] }

退出mongo shell

exit

3.2 以權限認證的方式啟動mongodb資料庫

sudo mongod --auth

啟動之后在啟動資訊中會有如下資訊,說明mongodb以權限認證的方式啟動成功

[initandlisten] options: { security: { authorization: "enabled" } }

3.3 登錄驗證

此時再使用資料庫各命令的時候會報權限錯誤,需要認證才能執行相應操作、

use admin
db.auth('python','python')
  • python用戶是創建在admin資料庫上的所以必須來到admin資料庫上進行認證

  • 認證成功會回傳1,失敗回傳0

4. 創建普通用戶

4.1 在使用的資料庫上創建普通用戶

1.選擇需要創建用戶的資料庫

use test1
  1. 創建用戶

db.createUser("user":"user1", "pwd":"pwd1", roles:["read"])
創建普通用戶user1,該用戶在test1上的權限是只讀
db.createUser("user":"user1", "pwd":"pwd1", roles:["readWrite"])
創建普通用戶user1,該用戶在test1上的權限是讀寫

4.2 在admin用戶資料庫上創建普通用戶

use admin
db.createUser({"user":"python1", "pwd":"python1", roles:[{"role":"read","db":"dbname1"},{"role":"readWrite","db":"dbname2"}
]})

在admin上創建python1用戶,python1用戶的權限有兩個,一個再dbname1上的只讀,另一個是在dbname2上的讀寫

5. 查看創建的用戶

show users
{
    "_id" : "admin.python",
    "user" : "python",
    "db" : "admin",
    "roles" : [
        {
            "role" : "root",
            "db" : "admin"
        }
    ]
}

6. 洗掉用戶

6.1 進入賬號資料所在的資料庫

use db_name

6.2 洗掉用戶

db.dropUser('python')

mongodb和python互動

1. mongdb和python互動的模塊

pymongo 提供了mongdb和python互動的所有方法 安裝方式: pip install pymongo

2. 使用pymongo

2.1 匯入pymongo并選擇要操作的集合

資料庫和集合能夠自動創建

2.1.1 無需權限認證的方式創建連接物件以及集合操作物件

from pymongo import MongoClient
?
client = MongoClient(host,port) # 如果是本地連接host,port引數可以省略
?
collection = client[db名][集合名]
# collection = client.db名.集合名 # 與上邊用法相同

2.1.2 需要權限認證的方式創建連接物件以及集合操作物件

from pymongo import MongoClient
from urllib.parse import quote_plus
?
user = 'python' # 賬號
password = 'python' # 密碼
host = '127.0.0.1' # host
port = 27017 # port
uri = "mongodb://%s:%s@%s" % (quote_plus(user),
                              quote_plus(password),
                              host)
# quote_plus函式:對url進行編碼
# uri = mongodb://python:python@127.0.0.1
client = MongoClient(uri, port=port)
collection = client.db名.集合名

2.2 insert()添加資料

insert可以批量的插入資料串列,也可以插入一條資料

collection.insert({一條資料})
collection.insert([{資料一},{資料二}])

2.2.1 添加一條資料

回傳插入資料的_id

ret = collection.insert({"name":"test10010","age":33})
print(ret)

2.2.2 添加多條資料

回傳ObjectId物件構成的串列

item_list = [{"name":"test1000{}".format(i)} for i in range(10)]
rets = collection.insert(item_list)
print(rets)
for ret in rets:
    print(ret)

2.3 find_one()查找一條資料

接收一個字典形式的條件,回傳字典形式的整條資料 如果條件為空,則回傳第一條

ret = client.test.test.find_one({'name': 'test10001'})
print(ret) # 包含mongodb的ObjectId物件的字典
_ = ret.pop('_id') # 清除mongodb的ObjectId物件的k,v
print(ret) 

2.4 find()查找全部資料

回傳所有滿足條件的結果,如果條件為空,則回傳全部 結果是一個Cursor游標物件,是一個可迭代物件,可以類似讀檔案的指標,但是只能夠進行一次讀取

rets = collection.find({"name":"test10005"}),
for ret in rets:
    print(ret)
for ret in rets: #此時rets中沒有內容
    print(ret)

2.5 update()更新資料(全檔案覆寫或指定鍵值,更新一潭訓多條)

  • 語法:collection.update({條件}, {'$set':{指定的kv或完整的一條資料}}, multi=False/True, upsert=False/True)

  • multi引數:默認為False,表示更新一條; multi=True則更新多條; multi引數必須和$set一起使用

  • upsert引數:默認為False; upsert=True則先查詢是否存在,存在則更新;不存在就插入

  • $set表示指定欄位進行更新

2.5.1 更新一條資料;全檔案覆寫;存在就更新,不存在就插入

data = {'msg':'這是一條完整的資料1','name':'哈哈'}
client.test.test.update({'haha': 'heihei'}, {'$set':data}, upsert=True)

2.5.2 更新多條資料;全檔案覆寫;存在就更新,不存在就插入

data = {'msg':'這是一條完整的資料2','name':'哈哈'} # 該完整資料是先查詢后獲取的
client.test.test.update({}, {'$set':data}, multi=True, upsert=True)

2.5.3 更新一條資料;指定鍵值;存在就更新,不存在就插入

data = {'msg':'指定只更新msg___1'}
client.test.test.update({}, {'$set':data}, upsert=True)

2.5.4 更新多條資料;指定鍵值;存在就更新,不存在就插入

data = {'msg':'指定只更新msg___2'}
client.test.test.update({}, {'$set':data}, multi=True, upsert=True)

2.6 delete_one()洗掉一條資料

collection.delete_one({"name":"test10010"})

2.7 delete_many()洗掉全部資料

collection.delete_many({"name":"test10010"})

3. pymongo模塊其他api

查看pymongo官方檔案或源代碼 http://api.mongodb.com/python/current/

關注我持續為您分享干貨內容,你的收藏、評論、點贊就是對我最大的支持!

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/291047.html

標籤:python

上一篇:Selenium萬字長文&&全網最詳(上)-王者筆記【??建議收藏??】

下一篇:別再亂找教程了!Python自學從入門到作業的教程和學習經驗,全都在這里了!

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more