SQL数据库多层嵌套 json转sql建表语句,SQL数据库里数组里对象数据怎么创建

1. uniapp sqlite 一个数组包含对象嵌套对象通过主外键方式插入数据库:

// 假设有一个对象数组,对象中包含嵌套对象
const objectsArray = [
  {
    parentObject: {
      id: 1,
      name: 'Parent 1',
      // 其他父对象属性
    },
    childObject: {
      id: 11,
      parentId: 1,
      name: 'Child 1 of Parent 1',
      // 其他子对象属性
    }
  },
  // 其他对象...
];
 
// 定义插入父对象和子对象的函数
function insertParentAndChild(db, parent, child) {
  // 插入父对象
  db.executeSql(`INSERT INTO parent_table (id, name) VALUES (?, ?);`, [parent.id, parent.name]).then(() => {
    // 插入子对象,引用父对象的ID
    db.executeSql(`INSERT INTO child_table (id, parentId, name) VALUES (?, ?, ?);`, [child.id, parent.id, child.name]).then(() => {
      console.log('Inserted successfully');
    }).catch(e => {
      console.error('Child insert error:', e);
    });
  }).catch(e => {
    console.error('Parent insert error:', e);
  });
}
 
// 使用uniapp的数据库API
const db = uni.openDatabase();
 
// 遍历数组并插入数据
objectsArray.forEach(obj => {
  insertParentAndChild(db, obj.parentObject, obj.childObject);
});

2. uniapp plus.sqlite一个数组包含对象嵌套对象通过主外键方式插入数据库

// 假设有一个数组arrayData,它包含对象,对象中又嵌套了对象
// 例如:
// arrayData = [
//   { id: 1, name: 'Tom', profile: { age: 25, city: 'New York' } },
//   { id: 2, name: 'Jerry', profile: { age: 30, city: 'Los Angeles' } }
// ];
 
// 使用uniapp plus.sqlite插入数组中的对象,对象包含嵌套对象,并且通过主外键关联
function insertData(db, arrayData) {
  db.transaction(function(tx) {
    // 创建主表和外键表
    tx.executeSql('CREATE TABLE IF NOT EXISTS main_table (id INTEGER PRIMARY KEY, name TEXT)');
    tx.executeSql('CREATE TABLE IF NOT EXISTS foreign_table (id INTEGER PRIMARY KEY, age INTEGER, city TEXT, main_id INTEGER, FOREIGN KEY(main_id) REFERENCES main_table(id))');
    
    // 循环插入数据
    arrayData.forEach(function(item) {
      // 插入主表数据
      tx.executeSql('INSERT INTO main_table (name) VALUES (?)', [item.name]);
      // 获取刚插入的主键ID
      tx.executeSql('SELECT last_insert_rowid() as lastId', [], function(tx, result) {
        var lastId = result.rows.item(0).lastId;
        // 插入外键表数据,并关联主键ID
        tx.executeSql('INSERT INTO foreign_table (age, city, main_id) VALUES (?, ?, ?)', [item.profile.age, item.profile.city, lastId]);
      });
    });
  });
}
 
// 使用示例
var db = plus.sqlite.openDatabase({name: 'mydb'});
insertData(db, arrayData);

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值