Many to many relationships&Assignment

表与表之间多对多关联

import json
import sqlite3

conn = sqlite3.connect('rosterdb.sqlite')
cur = conn.cursor()

# Do some setup
cur.executescript('''
DROP TABLE IF EXISTS User;
DROP TABLE IF EXISTS Member;
DROP TABLE IF EXISTS Course;

CREATE TABLE User (
    id     INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT UNIQUE,
    name   TEXT UNIQUE
);

CREATE TABLE Course (
    id     INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT UNIQUE,
    title  TEXT UNIQUE
);

CREATE TABLE Member (
    user_id     INTEGER,
    course_id   INTEGER,
    role        INTEGER,
    PRIMARY KEY (user_id, course_id)
)
''')

fname = raw_input('Enter file name: ')
if ( len(fname) < 1 ) : fname = 'roster_data.json'

# [
#   [ "Charley", "si110", 1 ],
#   [ "Mea", "si110", 0 ],

str_data = open(fname).read()
json_data = json.loads(str_data)

for entry in json_data:

    name = entry[0];
    title = entry[1];
    role=entry[2];
    cur.execute('''INSERT OR IGNORE INTO User (name) 
        VALUES ( ? )''', ( name, ) )
    cur.execute('SELECT id FROM User WHERE name = ? ', (name, ))
    user_id = cur.fetchone()[0]

    cur.execute('''INSERT OR IGNORE INTO Course (title) 
        VALUES ( ? )''', ( title, ) )
    cur.execute('SELECT id FROM Course WHERE title = ? ', (title, ))
    course_id = cur.fetchone()[0]

    cur.execute('''INSERT OR REPLACE INTO Member
        (user_id, course_id,role) VALUES ( ?, ?, ? )''', 
        ( user_id, course_id ,role) )

    conn.commit()

要点其实是需要再建立一张表用来存入course和users的primary key。
最后在SQL中输入

SELECT hex(User.name || Course.title || Member.role ) AS X FROM 
    User JOIN Member JOIN Course 
    ON User.id = Member.user_id AND Member.course_id = Course.id
    ORDER BY X
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Core Data 中,可以使用 relationships 来储存数组。具体来说,你可以创建一个实体(entity)来表示数组中的每个元素,然后使用 relationships 来将这些实体与父实体关联起来。 以下是一个示例: 假设你有一个名为 Person 的实体,每个人都有多个电话号码。你可以创建一个名为 PhoneNumber 的实体,用于表示每个电话号码。然后,你可以在 Person 实体中创建一个 to-many 的 relationships,将每个人与他们的电话号码关联起来。 下面是一些具体的步骤: 1. 创建 PhoneNumber 实体。这个实体应该包含一个属性,用于储存电话号码。 2. 创建 Person 实体。这个实体应该包含一个 to-many 的关系,用于储存每个人的电话号码。这个关系应该指向 PhoneNumber 实体。 3. 在 Xcode 中打开 Core Data 模型编辑器,创建 PhoneNumber 实体和 Person 实体之间的 relationships。这个关系应该是一个 to-many 的关系,并且应该有一个逆向关系,将它与 Person 实体关联起来。 4. 在代码中使用 relationships。当你想要为一个 Person 对象添加一个电话号码时,你可以创建一个新的 PhoneNumber 对象,并将它与 Person 对象的关系添加到关系集合中。 以下是一些示例代码: ```swift // 创建一个新的 Person 对象 let person = Person(context: managedObjectContext) // 创建一个新的 PhoneNumber 对象 let phoneNumber = PhoneNumber(context: managedObjectContext) phoneNumber.number = "1234567890" // 将 PhoneNumber 对象添加到 Person 对象的关系集合中 person.addToPhoneNumbers(phoneNumber) // 保存更改 try! managedObjectContext.save() ``` 这样,你就可以使用 relationships 来储存数组了。每个数组元素都会作为一个独立的实体储存在数据库中,并且与父实体通过 relationships 关联起来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值