> php教程 > PHP开发 > JsonDB의 사용 예

JsonDB의 사용 예

巴扎黑
풀어 주다: 2016-11-07 10:30:41
원래의
1845명이 탐색했습니다.

JsonDB는 Python으로 구현된 JSON 형식을 기반으로 하는 경량 데이터베이스 오픈 소스 프로젝트입니다. 프로젝트 주소는 https://github.com/hujiang001/jsonDB/입니다.

저자는 완전한 참조 문서를 제공하며 중국어로 되어 있어 시작하기가 매우 쉽습니다. 중국어 문서의 주소는 https://github.com/hujiang001/jsonDB/입니다. 위키/참조 문서 . 현재 이 문서는 프로젝트 프로젝트인 reference.md에도 포함되어 있습니다.

이 프로젝트는 예제도 제공합니다. 아래에 이 예제를 붙여넣으면 사용이 매우 간단하다는 것을 알 수 있습니다. 🎜 >

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

#!usr/bin/env python# -*- coding: utf-8 -*-from database import JSONDBif __name__=="__main__":

    shopDb = JSONDB('shop_db',hashSize=1)  #create shop db

    userDb = JSONDB('sellerDb',hashSize=1) #create user db

    #specify key

    shopDb.ensureKey('shop',['id'])

    shopDb.ensureKey('goods',['id'])

    userDb.ensureKey('seller',['id','name'])

    userDb.ensureKey('customer',['id','name'])    #for debugging, you can start perfDot and open debug switch

    shopDb.perfDotStart()

    userDb.perfDotStart()

    shopDb.debugSwitch(1)

    userDb.debugSwitch(1)    #insert data

    #here we insert some data

    for i in range(0,100):        #insert data one by one

        shopDb.insert('shop',[{'id':i, 'name':'my shop', 'description':'this is a telephone shop'}])    #inset a data list

    goodsList = [{'id':10001, 'class':'telephone', 'brand':'apple', 'color':'white'},

                 {'id':10002, 'class':'telephone', 'brand':'huawei', 'color':'black'},

                 {'id':10003, 'class':'telephone', 'brand':'zte', 'color':'white'},

                 {'id':10004, 'class':'telephone', 'brand':'xiaomi', 'color':'black'},

                 {'id':10005, 'class':'telephone', 'brand':'moto', 'color':'white'},

                 {'id':10006, 'class':'telephone', 'brand':'oppo', 'color':'black'},]

    shopDb.insert('goods',goodsList)

    sellersList = [{'id':0x34200,'name':'li','sex':'female','birth':'1985-09-03','tel':'0816-19876545432'},

                   {'id':0x34201,'name':'wang','sex':'male','birth':'1988-11-03','tel':'0816-2345453453'},

                   {'id':0x34202,'name':'hong','sex':'female','birth':'1995-10-19','tel':'0816-144567589'}]

    userDb.insert('seller',sellersList)

    customersList = [{'id':0x7800,'name':'zhu','sex':'female','profile':['dress','mother','sport']},

                   {'id':0x7801,'name':'rong','sex':'male','profile':['baby','read','tech']},

                   {'id':0x7802,'name':'guo','sex':'female','profile':['phone','dress','food']}]

    userDb.insert('customer',customersList)    #export to default file

    shopDb.exportToFile()

    userDb.exportToFile(fileName='user')    #find

    # find with key

    findList = shopDb.find('goods',filter={'id':{'$lt':10004}})

    JSONDB.rprint(findList)

    findList = shopDb.find('goods',filter={'id':10004})

    JSONDB.rprint(findList)

    findList = userDb.find('customer',filter={'name':'guo'})

    JSONDB.rprint(findList)    #delete

    shopDb.delete('goods',{'id':10005})    #update

    shopDb.update('goods',set={'class':'phone'})    #merge

    shopDb.merge(userDb)

    shopDb.exportToFile('mergeDb')    #show pref time

    shopDb.perfDotEnd()

    userDb.perfDotEnd()    #import

    importDb = JSONDB('importDb')

    importDb.debugSwitch(1)

    importDb.importFromFile(fileName='mergeDb')    #importDb.printAll()

    importDb.exportToFile()    print importDb

로그인 후 복사

관련 라벨:
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿