SQL自学指南:21天掌握核心概念

需积分: 0 1 下载量 116 浏览量 更新于2024-08-01 收藏 8.2MB PDF 举报
"SQL21日自学通(V1.0) 是一本中文版的教程,旨在帮助读者在21天内自学SQL。这本书由‘笨猪’翻译,提供了关于SQL的全面介绍,包括其历史、数据库设计、SQL语法、查询、表达式、函数、条件语句、运算以及SQL中的各种子句等内容。适合初学者入门和进阶学习。" 在SQL的自学旅程中,首先了解SQL的历史和数据库的发展是至关重要的。SQL(Structured Query Language)自1970年代以来已成为管理和处理关系型数据库的标准语言。它的发展伴随着数据库技术的进步,从最初的IBM System R到现在的各种数据库管理系统,如MySQL、Oracle、SQL Server等。 第一天的学习聚焦于SQL的基础,包括SQL简介和数据库结构的设计。了解SQL的基本概念,如表、列、记录和索引,是建立数据库系统的基础。此外,书中还概述了SQL总览,提到了一些常见的SQL开发工具,如MySQL Workbench、Microsoft SQL Server Management Studio等,这些工具方便用户编写和执行SQL查询。 第二天深入探讨了SELECT语句,这是SQL中最常用的查询语句。读者将学习如何选择和检索数据,包括基本的SELECT语法、目标字段的选择、背景知识以及实际操作的例子。书中的“问与答”和“校练场”部分提供了解决问题和巩固知识的机会。 第三天的内容涉及表达式和条件语句,这对于过滤和排序数据至关重要。读者会学习到如何使用比较运算符、逻辑运算符以及如何构造WHERE子句来实现特定的查询条件。 第四天,读者将接触SQL中的函数,这能够对数据进行更复杂的处理。书中详细介绍了各种函数,包括聚合函数如COUNT、SUM、AVG、MAX、MIN,以及统计函数如VARIANCE和STDDEV,还有日期/时间函数和数学函数。这些函数极大地增强了SQL处理数据的能力。 第五天,教程讲解了SQL中的子句,如GROUP BY、HAVING、ORDER BY等,它们用于对查询结果进行分组、筛选和排序。此外,还介绍了转换函数和一些其他实用的内置函数,帮助读者更好地操纵和格式化数据。 "SQL21日自学通"是一本全面的指南,涵盖了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++语法解释每一行代码,并说明作用

2023-06-10 上传