1.0.2 • Published 3 years ago

@lijixuan/dblist v1.0.2

Weekly downloads
-
License
MIT
Repository
-
Last release
3 years ago

DBList

npm i @lijixuan/dblist

对一组有规则的列表数据进行增删改查

const list = [
  {
    name: 'lidaxuan',
    age: 20,
    sex: '男',
    hobby: [ '不近女色', '玩游戏' ],
    id: 'A1',
  },
  {
    name: 'lidaxuan',
    age: 20,
    sex: '男',
    hobby: [ '不近女色', '跳舞' ],
    id: 'A2',
  },
  {
    name: 'lidaxuan',
    age: 20,
    sex: '男',
    hobby: [ '不近女色', '玩游戏' ],
    id: 'A3',
  },
  {
    name: 'lidaxuan',
    age: 21,
    sex: '男',
    hobby: [ '不近女色', '玩游戏' ],
    id: 'A1-1',
    pid: ['A1', 'A2']
  },
  {
    name: 'lidaxuan',
    age: 20,
    sex: '男',
    hobby: [ '不近女色', '唱歌' ],
    id: 'A1-2',
    pid: 'A1'
  },
  {
    name: 'lidaxuan',
    age: 21,
    sex: '男',
    hobby: [ '不近女色', '玩游戏' ],
    id: 'A1-1-1',
    pid: 'A1-1'
  },
  {
    name: 'lidaxuan',
    age: 20,
    sex: '男',
    hobby: [ '不近女色', '唱歌' ],
    id: 'A1-2-1',
    pid: 'A1-2'
  }
];

这样的有规则数据大家都很熟悉,假如我们要想知道数据中包含 age = 21 或者 age = 20 的数据有那些

生成一个 dblist 对象

const db = new DBList(list)
或者
const db = new DBList()
db.insert(list)

select 查询

匹配 age = 21 的所有数据

db.select({ age: 21 })

[
  { name: 'lidaxuan', age: 21, sex: '男', hobby: [ '不近女色', '玩游戏' ] },
  { name: 'lidaxuan', age: 21, sex: '女', hobby: [ '不近女色', '跳舞' ] }
]

匹配 id = 2 或者 age = 20 的所有数据

db.select({ age: [21, 20] });

[
  { name: 'lidaxuan', age: 20, sex: '男', hobby: [ '不近女色', '玩游戏' ] },
  { name: 'lidaxuan', age: 21, sex: '男', hobby: [ '不近女色', '玩游戏' ] },
  { name: 'lidaxuan', age: 20, sex: '男', hobby: [ '不近女色', '玩游戏' ] },
  { name: 'lidaxuan', age: 21, sex: '女', hobby: [ '不近女色', '跳舞' ] }
]

匹配 age = 21 并且 hobby = 玩游戏 的所有数据

db.select({ age: 21, hobby: '玩游戏' });

[
  { name: 'lidaxuan', age: 21, sex: '男', hobby: [ '不近女色', '玩游戏' ] }
]

insert 添加

添加单条数据

const value = { id: 5, value: '重庆' }

const key = db.insert(value) // 返回该条元素的唯一键值

添加多条数据

const values = [{ id: 6, value: '上海' },  { id: 7, value: '天津' }]

const keys: Array<string | number> = db.insert(values) // 以数组形式返回所有元素的唯一键值

update 修改

把所有 name = 静静 的数据中的 age 修改为 19

const where = { name: '静静' }  // 匹配条件
const newData = { age: 19 }     // 修改的数据

db.update(where, newData)

remove 删除

删除 age = 21 的数据

const where =   { age: 21 }    // 匹配条件,匹配那些数据需要删除
db.remove(where)

删除 name = 夏琪 或者 name = 游勇 的数据

const where =   { name: ['夏琪', '游勇'] }
db.remove(where)

flatten 处理递归数据

const list = [
  {
    id: 1,
    value: '北京',
    children: [
      {
        id: 2,
        value: '朝阳区',
        children: [
          {
            id: 4,
            value: '三里屯'
          }
        ]
      },
      {
        id: 3,
        value: '东城区'
      }
    ]
  },
  ...
]

解构上面的递归结构数据

const db = new DBList([], 'id', 'pid')
const data = db.flatten(list, 'children')  // children 为数据结构中的递归字段

[
  { id: 1, value: '北京', pid: 0 },
  { id: 2, value: '朝阳区', pid: 1 },
  { id: 4, value: '三里屯', pid: 2 },
  { id: 3, value: '东城区', pid: 1 }
]

pid 为自动生成的外键关系数据,详情参考下面的介绍

构造参数

new DBList(list, primaryKey, foreignKey)
字段是否可以为空说明默认值
name对象名称-
list实列化时默认执行一次 insert 方法[]
primaryKey主键 , 用于标识别当前数据"id"
foreignKey外键, 用于与哪条数据进行关联"pid" "
fristForeignValue第一层外键的值"0"
indexName记录每一个数据的顺序Number

测试数据

[
  {
    "id": "100",
    "name": "A",
    "pid": 0
  },
  {
    "id": "101",
    "name": "B",
    "pid": "100"
  },
  {
    "id": "102",
    "name": "C",
    "pid": "101"
  },
  {
    "id": "103",
    "name": "D",
    "pid": "102"
  },
  {
    "id": "104",
    "name": "E",
    "pid": "103"
  }
]

children 查询子级数据

查询 id = 100 的子级数据

const where = { id: '100' }
db.children(where)

[
  {
    "id": "101",
    "name": "B",
    "pid": "100"
  }
]

parent 查询父级数据

查询 id = 104 的父级数据 (父级返回的是对象,非数组)

const where = { id: '104' }
db.parent(where)

{
  "id": "103",
  "name": "D",
  "pid": "102"
}

childrenDeep 递归查询子级数据

该方法与 children 类似, children 只会查询一层子级数据,childrenDeep 则会进行递归查询

const where = { id: '100' }
db.childrenDeep(where)
// db.childrenDeep(where, 'children') 
// 第二个参数用于指定 children 列表的键值,默认 children

[
  {
    "id": "100",
    "name": "A",
    "pid": 0,
    "children": [
      {
        "id": "101",
        "name": "B",
        "pid": "100",
        "children": [
          {
            "id": "102",
            "name": "C",
            "pid": "101",
            "children": [
              {
                "id": "103",
                "name": "D",
                "pid": "102",
                "children": [
                  {
                    "id": "104",
                    "name": "E",
                    "pid": "103",
                    "children": []
                  }
                ]
              }
            ]
          }
        ]
      }
    ]
  }
]

parentDeep 递归查询父级数据

该方法与 parent 类似, parent 只会查询一层父级数据,parentDeep 则会进行递归查询

const where = { id: '104' }
db.parentDeep(where)

// db.parentDeep(where, 'parent') 
// 第二个参数用于指定 parent 列表的键值,默认 parent

[
  {
    "id": "104",
    "name": "E",
    "pid": "103",
    "parent": {
      "id": "103",
      "name": "D",
      "pid": "102",
      "parent": {
        "id": "102",
        "name": "C",
        "pid": "101",
        "parent": {
          "id": "101",
          "name": "B",
          "pid": "100",
          "parent": {
            "id": "100",
            "name": "A",
            "pid": 0
          }
        }
      }
    }
  }
]

clone 复制

执行 clone 时会返回一个正常的 Array 数据

const list = db.clone()

执行 clone 时处理每一条数据

const list = db.clone(item => {
	// todo
	return item;
});

like 模糊查询

查询 value 中带 的数据

const where = { value: '北' }
db.link(where)

[
  { id: 1, value: '北京' }
]

selectOne 查询

selectOne 与 select 使用上一样的,selectOne 在匹配到一条数据后则会停止匹配。该方法返回的为数据本身,非数组

查询 id = 5 的数据

const where = { id: 5 }

db.selectOne(where) 
{ id: 5, value: '重庆' }

如果我们已知需要查询的数据只会存在一条时可以设置查询条数, 尽可能减少匹配次数

const where = { id: 5 }

db.select(where, 1)
[
  { id: 5, value: '重庆' }
]

siblings

根据条件的匹配结果查询其兄弟元素

const where = { id: 5 }

db.siblings(where) 

[
  ...
]

childrenDeepFlatten

childrenDeep + flatten 把 childrenDeep 的数据做降维处理

parentDeepFlatten

parentDeep + flatten 把 parentDeep 的结果做降维处理

clear

清空所有数据

empty

清空元素几节点上的数据,只保留 primaryKey & foreignKey 属性

const where = { xxx }
db.empty(where)
1.0.2

3 years ago

1.0.0

3 years ago