student_sqlite3

#coding:utf-8

import sqlite3

# 定义一个创建数据库文件并添加Student表的函数
def create_db_and_table():
    # 先连上数据库文件
    connect = sqlite3.connect('student.db')
    cursor = connect.cursor()

    # AUTOINCREMENT约束:表示该字段自动增长,一般用于INTEGER类型。
    # UNIQUE约束:表示该字段值是唯一的。
    # NOT NULL约束:表示该字段值不允许为空。
    # IF NOT EXISTS:当Student表不存在时,再执行创建的sql语句,如果表已经存在,
则sql语句不再执行。可以避免异常。
    create_sql = 'CREATE TABLE IF NOT EXISTS Student 
(id INTEGER PRIMARY KEY  UNIQUE, name TEXT NOT NULL, age INTEGER, 
score FLOAT)'
    cursor.execute(create_sql)


    # 执行一个或多个事务
    connect.commit()
    cursor.close()
    connect.close()


# 添加学员信息
def add_student():
    connect = sqlite3.connect('student.db')
    cursor = connect.cursor()
    name = raw_input('请输入姓名:')
    age = input('请输入年龄:')
    score = input('请输入成绩:')
    # sql语句中%s如果代表的是字符串类型,需要加上引号。
    insert_sql = 'INSERT INTO Student (name, age, score) VALUES 
("%s", %d, %f)'%(name,age,score)
    cursor.execute(insert_sql)
    connect.commit()
    cursor.close()
    connect.close()

def select_all_student_info(is_total_number):
    connect = sqlite3.connect('student.db')
    cursor = connect.cursor()
    # select_sql = 'SELECT count(*) FROM Student' 查询表中一共多少条
数据记录,返回整数。
    # select_sql = 'SELECT (name, age) FROM Student' 只查询name及age
字段的值。
    if is_total_number == True:
        # 是在获取数据的总数量
        select_sql = 'SELECT count(*) FROM Student'
        res = cursor.execute(select_sql)
        # fetchone()是Cursor类中的一个方法,用于匹配一条数据
        # fetchall()是Cursor类中的一个方法,用于匹配多条数据
        count = res.fetchone()[0]
        return count
    else:
        # 查询所有学员数据
        select_sql = 'SELECT * FROM Student'
        result_list = cursor.execute(select_sql)
        for id, name, age, score in result_list:
            print id,'. ',name,age,score
    connect.commit()
    cursor.close()
    connect.close()

def update_student_info():
    # 修改之前,先查询所有学员的信息
    select_all_student_info(False)
    select_number = input('请选择要修改的学员编号:')
    # 需要动态从数据库的表中查询所有学员的数量
    while select_number < 1 or select_number > select_all_student_info
(True):
        select_number = input('学员编号错误,请重新选择要修改的学员编号:')
    # 获取修改过后的学员信息
    name = raw_input('请输入修改后的姓名:')
    age = input('请输入修改后的年龄:')
    score = input('请输入修改后的成绩:')

    update_sql = 'UPDATE Student SET name="%s", age=%d, score=%f WHERE 
id=%d'%(name,age,score,select_number)
    connect = sqlite3.connect('student.db')
    cursor = connect.cursor()
    cursor.execute(update_sql)
    connect.commit()
    cursor.close()
    connect.close()

def delete_student_info():
    print '1-删除指定的学员信息'
    print '2-删除所有的学员信息'
    connect = sqlite3.connect('student.db')
    cursor = connect.cursor()
    select_number = input('请选择操作编号:')
    # 声明变量,用于记录最终执行的是1中的sql语句还是2中的sql语句
    delete_sql = ""
    if select_number == 1:
        select_all_student_info(False)
        number = input('请选择要删除的学员编号:')
        while number < 1 or number > select_all_student_info(True):
            number = input('学员编号错误,请重新选择要删除的学员编号:')
        delete_sql = 'DELETE FROM Student WHERE id=%d'%number
    else:
        # 默认是清空表中的所有数据
        delete_sql = 'DELETE FROM Student'

    cursor.execute(delete_sql)
    connect.commit()
    cursor.close()
    connect.close()


if __name__ == '__main__':
    create_db_and_table()
    # select_all_student_info(True)
    while True:
        print '''
        1. 添加学员信息
        2. 修改学员信息
        3. 查询学员信息
        4. 删除学员信息
        0. 退出程序
        '''
        select_number = input('请选择操作:')
        if select_number == 1:
            add_student()
            print '\n添加学员成功!\n'
        elif select_number == 2:
            update_student_info()
            print '\n修改学员信息成功!\n'
        elif select_number == 3:
            select_all_student_info(False)
        elif select_number == 4:
            delete_student_info()
            print '\n删除学员信息成功!\n'
        else:
            break

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是我的代码:import sqlite3 conn = sqlite3.connect('C:\\Users\\Dell\\Desktop\\studentsTXL.db') conn.execute('create table if not exists students (stunum primary key,name,number)') #conn.execute('CREATE TABLE students(stunum INT PRIMARY KEY NOT NULL,name TEXT NOT NULL,number INT NOT NULL);') def add_student(): student_number = int(input('请输入学生学号:')) name = input('请输入学生姓名:') number = int(input('请输入学生电话:')) conn.execute(f"insert into sudents (stunum,name,number) values ({student_number},'{name}',{number})") conn.commit() print('学生信息添加成功') def delete_student(): student_number= int(input('请输入要删除的学生学号:')) conn.execute(f"delete from students where stunum={student_number}") conn.commit() print('学生信息删除成功') def modify_student(): student_number = int(input('请输入要修改的学生的学号:')) name = input('请输入学生姓名:') number = int(input('请输入学生电话:')) conn.execute(f"update students set name='{name}', number={number} where stunum={student_number}") conn.commit() print('学生信息修改成功') # 查询学生信息 def query_student(): student_number = int(input('请输入要查询的学生学号:')) cursor = conn.execute(f"select * from students where stunum={student_number}") row = cursor.fetchone() if row is None: print('无学生信息') else: print(f'学生学号:{row[0]},姓名:{row[1]},电话:{row[2]}') # 主程序 while True: print('这是学生信息管理系统') print('1. 添加学生信息') print('2. 删除学生信息') print('3. 修改学生信息') print('4. 查询学生信息') print('5. 退出系统') choice = int(input('请选择要执行的操作:')) if choice == 1: add_student() elif choice == 2: delete_student() elif choice == 3: modify_student() elif choice == 4: query_student() elif choice == 5: break else: print('无此项选择') conn.close(),在运行且输入学生信息后,查询显示无学生信息,请问如何改正
06-09

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值