小案例:javascript实现对json文件的增删改查

下面为books.json格文件的数据

[{
    "id": 1,
    "bookName": "完美世界",
    "author": "辰东",
    "hero": "石昊"
}, {
    "id": 2,
    "bookName": "武庚纪",
    "author": "沈乐平",
    "hero": "武庚"
}, {
    "id": 4,
    "bookName": "天行九歌",
    "author": "陈岚",
    "hero": "韩非"
}]

下面为books.js文件的数据

// 实现对json数据的增删改查
// 先引入所需的模块
let { join } = require('path')
let { readFile, writeFile } = require('fs')
const { json } = require('stream/consumers')
// 拼接json文件的绝对路径
let filePath = join(__dirname, 'books.json')

// 查询数据 --> 其实就是查询文件的内容
function query() {
    // err为错误 data为查询到的数据
    // 当没有错误时,err为空对象,有错误时,err内是错误信息
    readFile(filePath, 'utf-8', (err, data) => {
        // 如果有错误就抛出错误信息,并不再向下执行
        if (err) throw err
        // 将获取到的字符串数据转为对象类型
        let res = JSON.parse(data)
        console.log(res) // 查询到的数据
    })
}
// query()

// 增加数据
function add(obj) {
    readFile(filePath, 'utf-8', (err, data) => {
        if (err) throw err
        let res = JSON.parse(data)
        // 需要得到id,id为数组中最后一个图书的id+1
        let index = res[res.length - 1].id + 1
        // 向obj对象中添加id属性
        obj.id = index
        res.push(obj)
        // 写入到json文件中 --> 需要把res转为字符串写入到json文件
        writeFile(filePath, JSON.stringify(res), err => {
            if (err) throw err
            console.log('添加成功')
        })
    })
}
// add({ bookName: "斗罗大陆", author: "唐家三少", hero: "唐三" })

// 修改数据   --> 其实就是把原数据删除,把修改的数据放进去
// 根据图书id修改
function upData(obj) {
    readFile(filePath, 'utf-8', (err, data) => {
        if (err) throw err
        let res = JSON.parse(data)
        // 使用数组的splice方法
        // splice(索引,删除的个数,新增的数据)
        // 可以用数组的findIndex方法获取索引
        // findIndex(item =>return 条件) 返回符合条件的数据的索引
        let index = res.findIndex(item => obj.id === res.id)
        res.splice(index, 1, obj)
        writeFile(filePath, JSON.stringify(res), err => {
            if (err) throw err
            console.log('修改成功')
        })
    })
}
// 修改id为3的图书信息为:天官赐福、墨香铜臭、谢怜
// upData({ id: 3, bookName: "天官赐福", author: "墨香铜臭", hero: "谢怜" })

// 删除数据
// 根据图书的id删除对应的数据
function del(id) {
    readFile(filePath, 'utf-8', (err, data) => {
        if (err) throw err
        let res = JSON.parse(data)
        // 数组的filter方法可以返回满足筛选条件的结果
        let r = res.filter(item => {
            // 只有当图书的id不为3,才返回结果
            return id !== item.id
        })
        writeFile(filePath, JSON.stringify(r), err => {
            if (err) throw err
            console.log('删除成功')
        })
    })
}
// 删除图书id为3的数据
del(3)
### 回答1: SQL Server中的默认约束是一种约束,它定义了在插入新行时,如果没有为该列提供值,则将使用默认值。默认约束可以在创建表时定义,也可以在后期添加到表中。默认约束可以是常量、表达式或函数。如果没有为列定义默认约束,则该列将接受NULL值。 ### 回答2: SQL Server中的默认约束(Default Constraint)是一种用于指定默认值的对象,该对象将在插入数据时自动添加到表中。默认约束可用于任何表中的任何列,以确保在没有明确提供值的情况下为列提供默认值,也可以用于用户界面或代码中省略某些列值的情况。 默认约束可以在创建表时使用CREATE TABLE命令来定义,也可以通过使用ALTER TABLE命令在现有表中添加。以下是一些默认约束的示例: 示例1:在创建表时添加默认约束 CREATE TABLE myTable ( myColumn INT DEFAULT 0 ) 示例2:在现有表中添加默认约束 ALTER TABLE myTable ADD CONSTRAINT myDefaultConstraint DEFAULT 0 FOR myColumn 示例3:删除现有默认约束 ALTER TABLE myTable DROP CONSTRAINT myDefaultConstraint 默认约束可以在添加或更新行时显式地提供覆盖值。例如,在上面的第一个示例中,如果想将我的列的值设置为5而不是0,则可以在插入数据时提供一个值,并将其覆盖默认值,如下所示: INSERT INTO myTable(myColumn) VALUES (5) 总之,SQL Server的默认约束是一个非常有用的功能,可确保在没有提供值的情况下,任何表中的列都有默认值。通过使用默认约束,可以减少手动输入和代码编写的工作量,并确保数据表的一致性和完整性。 ### 回答3: SQL Server的DEFAULT约束是一个用于定义默认值的约束。它可以应用于表中的列,用于在没有提供任何值的情况下为列提供默认值。DEFAULT约束可以包含任何常数或标量表达式,该表达式返回所需的默认值。 在创建表时,可以通过以下命令来定义DEFAULT约束: CREATE TABLE 表名( 列名 数据类型 DEFAULT 默认值 ); 例如,可以使用以下命令在表中创建一个DEFAULT约束: CREATE TABLE Employee ( EmployeeID INT, FirstName VARCHAR(50), LastName VARCHAR(50), HireDate DATE DEFAULT GETDATE() ); 在这个例子中,HireDate列使用DEFAULT约束来提供默认值。如果在插入记录时不为HireDate列提供任何值,它将自动设置为当前日期。 同样,DEFAULT约束可以使用ALTER TABLE命令在表中进行修改和删除。例如,以下命令可以修改表Employee中HireDate列的DEFAULT约束: ALTER TABLE Employee ALTER COLUMN HireDate SET DEFAULT '2021-01-01'; 通过这种方式,DEFAULT约束将被更改为提供2021年1月1日作为默认值。 值得注意的是,如果列上已经有约束,那么DEFAULT约束将与这个约束一起工作。这意味着如果在列上定义了NOT NULL约束,则必须为该列提供值,DEFAULT约束不能用于提供默认值。 在SQL Server中,DEFAULT约束是非常有用和常见的约束之一,它可以简化编程工作并提高数据的一致性和完整性。因此,在设计基于SQL Server的数据库时,DEFAULT约束应该得到充分的考虑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值