SQL基础练习题:查询与条件筛选实战

需积分: 10 0 下载量 28 浏览量 更新于2024-08-24 收藏 7KB MD 举报
SQL(Structured Query Language)是一种用于管理和处理关系型数据库的标准编程语言,本文档提供了一系列SQL练习题,旨在帮助学习者巩固和理解SQL的基本语法和功能。以下是每个知识点的详细解释: 1. SELECT查询基本格式: SQL查询的核心是`SELECT`语句,用于从表中选择数据。其基本结构包括:选择要显示的字段(如`*`表示所有字段)、`FROM`指定数据来源的表、`WHERE`用于筛选特定条件、`GROUP BY`用于分组数据、`HAVING`条件对分组后的数据进行过滤、`ORDER BY`用于排序结果、以及`LIMIT`用于限制返回的记录数量。 2. 字段操作: - `SELECT * FROM stu;`:选取所有字段。 - `SELECT uname, sex, age FROM stu;`:选取指定的三个字段。 - `SELECT uname, sex, age + 10 FROM stu;`:计算10年后的年龄。 - `SELECT uname, sex, age+10 as xxoo FROM stu;`:为字段起别名。 - `SELECT u.uname, u.sex, u.age FROM stu as u;`:使用别名给表名指定别名。 3. 列合并和去重: - `SELECT uname, concat(age, '====', sex) as xxoo FROM stu;`:合并多个字段值。 - `SELECT distinct classid, sex FROM stu;`:去除重复的`classid`和`sex`组合。 4. 添加虚拟列: - `SELECT *,'四川校区' FROM stu;`:在查询结果中插入固定值。 - `SELECT *,'四川校区' as '校区' FROM stu;`:为新插入的列指定别名。 5. 条件筛选: - `SELECT * FROM stu WHERE classid = 'php216';`:筛选特定班级。 - `SELECT * FROM stu WHERE classid = 'php216' AND sex = 'w';`:同时筛选班级和性别。 - `SELECT * FROM stu WHERE age > 20;`:年龄大于20的学生。 - `SELECT * FROM stu WHERE age BETWEEN 30 AND 40;`:年龄在30到40之间。 - `SELECT * FROM stu WHERE age NOT BETWEEN 20 AND 30;`:排除年龄在20到30之间的学生。 - `SELECT * FROM stu WHERE (classid = 'php216' OR classid = 'php219') AND sex = 'w';`:筛选两个班级的女生。 - `SELECT * FROM stu WHERE (classid = 'php216' OR classid = 'php219') AND sex != 'm';`:排除男生,得到女生。 这些SQL练习题涵盖了SQL查询的基础操作,包括字段选择、条件过滤、分组和排序,以及数据去重和虚拟列的创建。通过这些题目,学习者可以逐步掌握如何根据实际需求编写SQL查询语句,提高数据库操作的能力。

// 查询全部数据,这里需要改造一下,我们传入一个空容器,然后,把数据弄出去 void SqOperator::queryTable(QList<QString> &list) { QSqlQuery sqlQuery; sqlQuery.exec("SELECT * FROM idinfo"); if(!sqlQuery.exec()) { qDebug() << "Error: Fail to query table. " << sqlQuery.lastError(); } else { while(sqlQuery.next()) { QString usrname = sqlQuery.value(0).toString(); list.append(usrname); QString usrpass = sqlQuery.value(1).toString(); list.append(usrpass); //qDebug()<<QString("id:%1 name:%2").arg(id).arg(name); } } } // 插入单条数据 bool SqOperator::singleInsertData(info &singledb) { QSqlQuery sqlQuery; sqlQuery.prepare("INSERT INTO idinfo VALUES(:usrname,:usrpass)"); sqlQuery.bindValue(":usrname", singledb.usrname); sqlQuery.bindValue(":usrpass", singledb.usrpass); if(!sqlQuery.exec()) { qDebug() << "Error: Fail to insert data. " << sqlQuery.lastError(); return false; } else { qDebug() <<"insert success."; // do something return true; } } // 插入多条数据 void SqOperator::moreInsertData(QList<info>& moredb) { // 进行多个数据的插入时,可以利用绑定进行批处理 QSqlQuery sqlQuery; sqlQuery.prepare("INSERT INTO idinfo VALUES(?,?,?)"); QVariantList nameList,passList; for(int i=0; i< moredb.size(); i++) { nameList << moredb.at(i).usrname; passList << moredb.at(i).usrpass; } sqlQuery.addBindValue(nameList); sqlQuery.addBindValue(passList); if (!sqlQuery.execBatch()) // 进行批处理,如果出错就输出错误 { qDebug() << sqlQuery.lastError(); } } // 修改数据 void SqOperator::modifyData(QString usrname,QString usrpass) { QSqlQuery sqlQuery; sqlQuery.prepare("UPDATE student SET usrname=?,usrpass=?"); sqlQuery.addBindValue(usrname); sqlQuery.addBindValue(usrpass); if(!sqlQuery.exec()) { qDebug() << sqlQuery.lastError(); } else { qDebug() << "updated data success!"; } } // 删除数据 void SqOperator::deleteData(QString usrname) { QSqlQuery sqlQuery; sqlQuery.exec(QString("DELETE FROM student WHERE id = %1").arg(usrname)); if(!sqlQuery.exec()) { qDebug()<<sqlQuery.lastError(); } else { qDebug()<<"deleted data success!"; } } //删除数据表 void SqOperator::deleteTable(QString& tableName) { QSqlQuery sqlQuery; sqlQuery.exec(QString("DROP TABLE %1").arg(tableName)); if(sqlQuery.exec()) { qDebug() << sqlQuery.lastError(); } else { qDebug() << "deleted table success"; } } void SqOperator::closeDb(void) { database.close(); }用C++语法解释每一行代码,并说明作用

190 浏览量