当前位置:   article > 正文

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

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

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

  1. // 假设有一个对象数组,对象中包含嵌套对象
  2. const objectsArray = [
  3. {
  4. parentObject: {
  5. id: 1,
  6. name: 'Parent 1',
  7. // 其他父对象属性
  8. },
  9. childObject: {
  10. id: 11,
  11. parentId: 1,
  12. name: 'Child 1 of Parent 1',
  13. // 其他子对象属性
  14. }
  15. },
  16. // 其他对象...
  17. ];
  18. // 定义插入父对象和子对象的函数
  19. function insertParentAndChild(db, parent, child) {
  20. // 插入父对象
  21. db.executeSql(`INSERT INTO parent_table (id, name) VALUES (?, ?);`, [parent.id, parent.name]).then(() => {
  22. // 插入子对象,引用父对象的ID
  23. db.executeSql(`INSERT INTO child_table (id, parentId, name) VALUES (?, ?, ?);`, [child.id, parent.id, child.name]).then(() => {
  24. console.log('Inserted successfully');
  25. }).catch(e => {
  26. console.error('Child insert error:', e);
  27. });
  28. }).catch(e => {
  29. console.error('Parent insert error:', e);
  30. });
  31. }
  32. // 使用uniapp的数据库API
  33. const db = uni.openDatabase();
  34. // 遍历数组并插入数据
  35. objectsArray.forEach(obj => {
  36. insertParentAndChild(db, obj.parentObject, obj.childObject);
  37. });

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

  1. // 假设有一个数组arrayData,它包含对象,对象中又嵌套了对象
  2. // 例如:
  3. // arrayData = [
  4. // { id: 1, name: 'Tom', profile: { age: 25, city: 'New York' } },
  5. // { id: 2, name: 'Jerry', profile: { age: 30, city: 'Los Angeles' } }
  6. // ];
  7. // 使用uniapp plus.sqlite插入数组中的对象,对象包含嵌套对象,并且通过主外键关联
  8. function insertData(db, arrayData) {
  9. db.transaction(function(tx) {
  10. // 创建主表和外键表
  11. tx.executeSql('CREATE TABLE IF NOT EXISTS main_table (id INTEGER PRIMARY KEY, name TEXT)');
  12. 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))');
  13. // 循环插入数据
  14. arrayData.forEach(function(item) {
  15. // 插入主表数据
  16. tx.executeSql('INSERT INTO main_table (name) VALUES (?)', [item.name]);
  17. // 获取刚插入的主键ID
  18. tx.executeSql('SELECT last_insert_rowid() as lastId', [], function(tx, result) {
  19. var lastId = result.rows.item(0).lastId;
  20. // 插入外键表数据,并关联主键ID
  21. tx.executeSql('INSERT INTO foreign_table (age, city, main_id) VALUES (?, ?, ?)', [item.profile.age, item.profile.city, lastId]);
  22. });
  23. });
  24. });
  25. }
  26. // 使用示例
  27. var db = plus.sqlite.openDatabase({name: 'mydb'});
  28. insertData(db, arrayData);

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/646277
推荐阅读
相关标签
  

闽ICP备14008679号