已知创建了一个数据库Student(内建数据表stu1),以此执行import sqlite3、con=sqlite3.connect (’Student’ )、cur=con.cursor ()后,能完成查询任务的操作是
时间: 2023-12-10 16:39:01 浏览: 24
以下是查询任务的操作示例:
1. 查询所有学生信息:
```python
cur.execute("SELECT * FROM stu1")
results = cur.fetchall()
for row in results:
print(row)
```
2. 查询学号为1001的学生信息:
```python
cur.execute("SELECT * FROM stu1 WHERE id=1001")
results = cur.fetchall()
for row in results:
print(row)
```
3. 查询所有年龄大于等于18岁的学生信息:
```python
cur.execute("SELECT * FROM stu1 WHERE age>=18")
results = cur.fetchall()
for row in results:
print(row)
```
4. 查询所有女生的信息:
```python
cur.execute("SELECT * FROM stu1 WHERE gender='female'")
results = cur.fetchall()
for row in results:
print(row)
```
注意:以上示例中的表名、字段名和条件都需要根据实际情况进行修改。
相关问题
依次执行import sqlite3 、 con=sqlite3connect('stu')、cur=concursor()后,下列操作正确的是
以下是正确的操作:
1. 创建一个表:
```
cur.execute("CREATE TABLE students (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)")
```
2. 插入一条记录:
```
cur.execute("INSERT INTO students (id, name, age) VALUES (1, 'Tom', 20)")
con.commit()
```
3. 查询记录:
```
cur.execute("SELECT * FROM students")
rows = cur.fetchall()
for row in rows:
print(row)
```
4. 更新记录:
```
cur.execute("UPDATE students SET age = 21 WHERE name = 'Tom'")
con.commit()
```
5. 删除记录:
```
cur.execute("DELETE FROM students WHERE name = 'Tom'")
con.commit()
```
注意:在执行完所有操作后,应该关闭连接和游标:
```
cur.close()
con.close()
```
20210150章明一班男 20210123李悦灵二班女 20210913欧阳紫玉一班女 读取文本文件data.txt,将学号、姓名、班级、性别插入到数据库Student.db的stu表中 import salite3 con = sqlite3.connect('student.db' cur = con.cursor0) cur.execute('create table if not exists stus(id primary key,name text,cla text,sex text)fr = open(dat.txt',r) for line in frreadlines(): L=len(line) if line[-1]=='n' L=L-1line=line[o:L]xh=line[0:8] xm=line[8:L-3] bj=line[L xb=line[L-1:]print(xh,xm,xb) values(?,?,?,?),(xh,xm,bj,xb))cur.execute(insert intofr.close()con.commit0)cur.close() con.close()
在您提供的代码中,存在一些语法错误和逻辑错误,可以参考以下代码进行修改:
```python
import sqlite3
conn = sqlite3.connect('Student.db')
cur = conn.cursor()
cur.execute('''CREATE TABLE IF NOT EXISTS stu
(id TEXT PRIMARY KEY,
name TEXT,
cla TEXT,
sex TEXT);''')
with open('data.txt', 'r') as f:
lines = f.readlines()
for line in lines:
line = line.strip()
xh = line[0:8]
xm = line[8:-3]
bj = line[-3:-1]
xb = line[-1:]
cur.execute("INSERT INTO stu (id, name, cla, sex) VALUES (?, ?, ?, ?)", (xh, xm, bj, xb))
conn.commit()
cur.close()
conn.close()
```
代码的改动主要包括:
1. 修改了数据库文件名为 `Student.db`;
2. 修改了 `CREATE TABLE` 语句中的主键类型为 `TEXT`;
3. 修改了 `INSERT INTO` 语句中的参数顺序;
4. 修改了读取文件的方式,使用了 `with open()`;
5. 对读取的每一行进行了 `strip()` 操作,去除了多余的空格和换行符;
6. 修改了提取姓名、班级和性别的逻辑,使用了字符串的切片操作。
请注意,以上代码仅供参考,您需要根据自己的具体情况进行修改和调试。