SQL语言详解:从基础到DML操作

5星 · 超过95%的资源 需积分: 5 3 下载量 26 浏览量 更新于2024-08-05 收藏 86KB MD 举报
"这是一份关于SQL的笔记,涵盖了SQL的基本概念和主要的DML(数据库操作语言)语法,包括INSERT INTO、UPDATE和DELETE语句的使用方法。" SQL,即结构化查询语言,是用于管理和处理关系型数据库的标准语言。自1986年起,SQL已经成为美国国家标准化组织(ANSI)和国际标准化组织(ISO)的标准,目前广泛遵循的是92标准。它主要用于关系型数据库管理系统(RDBMS),尽管在非关系型数据库(NoSQL)中也有部分应用。 在DML部分,笔记介绍了三种基本操作: 1. INSERT INTO:这是向数据库表中添加新记录的命令。有两种形式: - 第一种不指定列名,只提供值,适用于所有列都需要赋值的情况。 ```sql INSERT INTO TABLE_name VALUES (value1, value2, value3); ``` - 第二种指定列名及对应的值,适用于部分列赋值或明确赋值顺序。 ```sql INSERT INTO TABLE_name (column1, column2, column3) VALUES (value1, value2, value3); ``` 另外,`INSERT INTO SELECT` 用于从一个表中选择数据并插入到另一个表,如示例所示。 2. UPDATE:用于修改现有记录。更新语句包含要更新的表名、设置的新值和WHERE子句来指定更新条件。 ```sql UPDATE table_name SET column1 = value1, column2 = value2 WHERE some_column = some_value; ``` 没有WHERE子句的UPDATE会更新表中的所有记录,因此需谨慎操作。在MySQL中,可以启用`sql_safe_updates`参数来强制要求UPDATE语句包含WHERE条件。 3. DELETE:用于从表中删除记录。删除操作也需指定表名和WHERE子句来限定删除条件。 ```sql DELETE FROM table_name WHERE some_column = some_value; ``` 或者,`DELETE * FROM`可以删除表中的所有记录,但通常不建议这样做,除非确实需要清空整个表。 这些基本操作构成了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 上传