搜索
首页数据库mysql教程SQL语句简单语法

SQL语句基本的四大元素(增,删,改,查) 插入数据 语法:INSERT INTO 表名(字段1,字段2,...)VALUES(值1,值2,...) 其中,INTO可选. 例如:将姓名张三学号s2t14年龄22插入到stuInfo表中的stuName,stuNo,stuAge这三个字段中。 INSERT INTO stuInfo (stuName,stuNo,st

   SQL语句基本的四大元素(增,删,改,查) 插入数据

  语法:INSERT INTO 表名(字段1,字段2,...)VALUES(值1,值2,...)

  其中,INTO可选.

  例如:将姓名‘张三’学号‘s2t14’年龄22插入到stuInfo表中的stuName,stuNo,stuAge这三个字段中。

  INSERT INTO stuInfo (stuName,stuNo,stuAge) VALUES ('张三','s2t14',22)

  插入多行数据

  1.通过INSERT SELECT语句将现有表中的数据添加到新表

  语法:INSERT INTO 新表名(字段1,字段2,...)SELECT 字段1,字段2,... FROM 原表名

  例如:INSERT INTO TongXunLu(‘Name’,‘Address’,‘Email’)SELECT SName,SAddress,SEmail FROM Students

  2.通过SELECT INTO语句将现有表中的数据添加到新表

  语法:SELECT 表名.字段1,表名.字段2,... INTO 新表名 FROM 原表名

  例如:SELECT Students.SName,Students.SAddress,Students.SMail INTO TongXunLu FROM Students

  因为标识列的数据是不允许指定的,因此我们可以创建一个新的标识列

  语法:SELECT IDENTITY (数据类型,标识种子,标识增长量) AS 列名 INTO 新表名 FROM 原表名

  例如:SELECT Students.SName,Students.SAddress,Students.SMail,IDENTITY(int,1,1)AS StudentsID INTO TongXunLu FROM Students

  3.通过UNION关键字合并数据进行插入

  UNION语句用于将两个不同数据或查询结果组合的一个新的结果集,当然,不同的数据或查询结果,也要求数据个数、顺序、数据类型都一致,因此,当向表中重复插入多次数据的时候,可以使用SELECCT...UNION来简化操作。

  例如:INSERT Students(SName,SGrade,SSex)

  SELECT '女生1',7,0 UNION

  SELECT '女生2',7,0 UNION

  SELECT '女生3',7,0 UNION

  SELECT '女生4',7,0 UNION

  SELECT '女生5',7,0 UNION

  SELECT '男生1',7,1 UNION

  SELECT '男生2',7,1 UNION

  SELECT '男生3',7,1 UNION

  SELECT '男生4',7,1 删除数据

  语法:DELETE FROM 表名 WHERE (条件)

  例如:删除stuInfo表中年龄小于20岁的学生。

  DELETE FROM stuInfo WHERE stuAge

  TRUNCATE TABLE用来删除表中所有行的命令,功能上它类似于没有WHERE子句的DELETE语句。

  例如:要删除学员信息表中的所有记录行,可以使用。

  TRUNCATE TABLE Students

  提示:TRUNCATE TABLE 删除表中的所有行,但是表的结构、列、约束、索引等不会被改动。TRUNCATE TABLE不能用于有外键约束引用的表,这种情况下,需要使用DELETE语句。 修改数据

  语法:UPDATE 表名 SET 字段1=值1,字段2=值2,... WHERE (条件)

  例如:将stuInfo表中姓名是张三的学生年龄修改为25岁。

  UPDATE stuInfo SEF stuAge = 25 WHERE stuName = '张三'

  还可以通过表达式来更新数据。

  例如:需要在成绩表中更新成绩,所有低于85分的都在原来的基础上加5分,更新的SQL语句如下。

  UPDATE Scores SET Scores =Scores 5 WHERE Scores

  1.查询所有的数据行和列

  把表中所有数据行和列到列举出来需要使用“*”通配符来表示所有的列。

  例如:查询Students表中的所有数据。

  SELECT * FROM Students

  2.条件查询

  语法:SELECT 字段1,字段2,...FROM 表名

  例如:查询stuInfo表中所有学生的姓名(stuName)和年龄(stuAge)两个字段。

  SELECT stuName,stuAge FROM stuInfo

  3.在查询中使用列名

  AS子句可以用来改变结果集列的名称,还有一种情况是要让标题列的信息更易懂。

  例如:把SCode列名查询后显示为“学员编号”

  SELECT SCode AS 学员编号,SName AS 学员姓名 FROM Students

  还有一种情况是使用计算、合并得到新列的命名。

  例如:在查询Employees表中的数据时,需要把FirstName和LastName字段合并成一个叫“姓名”的字段。

  SELECT FirstName '.' LastName AS '姓名'FROM Employees 或者

  SELECT '姓名'= FirstName '.' LastName FROM Employees

  4.查询空行

  在SQL语句中采用“IS NULL”或者“IS NOT NULL”来判断是否为空行。

  例如:要查询学员信息表中没有填写Email信息的学员,可以使用以下查询语句。

  SELECT SName FROM Students WHERE SEmail IS NULL

  5.在查询中使用常量列

  有的时候,一些常量的缺省信息需要添加到查询输出中,以方便统计或计算。

  例如:查询学员信息的时候,学校名称统一都是“河北新龙”,查询输出的语句为。

  SELECT 姓名=SName,地址=SAddress,'河北新龙' AS 学校名称 FROM Students

  6.查询返回限制的行数

  例如:在测试的时候,如果数据库中有上万条记录,而只要检查前面十行数据是否有效。

  SELECT TOP 10 SName,SAddress FROM Students WHERE SSex = 0 查询排序

  如果需要按照一定的顺序排列查询语句选中的行,需要使用ORDER BY子句,并且排序可以是升序(ASC)或者降序(DESC)。如果不指定ASC或者DESC,缺省记录集按ASC升序排序。上面讲述的SQL语句都可以在其后面加上ORDER BY来进行排序。

  例如:查询学员成绩的时候,如果把所有成绩都降低10%后加5分,再按照及格成绩的高低来进行排列。

  SELECT StudentID AS 学员编号,(Score*0.9 5)AS 综合成绩 FROM Score WHERE (Score*0.9 5)>60 ORDER BY Score

  还可以按照多个字段进行排序。

  例如:要在学员成绩的基础上,再按照课程ID进行排序的语句如下。

  SELECT StudentID AS 学员编号,Score AS 成绩 FROM Score WHERE Score>60 ORDER BY Score,CourseID

  特殊排序

  在数据库表中有以下字符数据,如:

  13-1、13-10、13-100、13-108、14-3、14-1、13-18

  现在希望通过SQL语句进行排序,并且首先要按照前半部分的数字进行排序,然后再按照后半部分的数字进行排序,输出要排成这样:13-1、13-10、13-18、13-100、13-108、14-1、14-3

  数据库表名:SellRecord;字段名:ListNumber

  分析:

  这是查询语句,需要使用SELECT语句,,需要用到ORDER BY进行排序,并重新计算出排序的数字来。

  前半部分的数字,可以从先找到“-”符号的位置,然后取其左半部分,最后再使用Convert函数将其转换为数字。

  Convert(int,Left(ListNumber,CharIndex('-',ListNumber)-1))

  后半部分的数字,可以先找到“-”符号的位置,然后把从第一个位置到该位置的全部字符替换为空格,最后再使用Convert函数将其转换为数字。

  Convert(int,Stuff(ListNumber,1,Charindex('-',ListNumber),''))

  完整的T-SQL语句是:

  SELECT ListNumber

  FROM SellRecord

  ORDER BY Convert(int,Left(ListNumber,CharIndex('-',ListNumber)-1)),Convert(int,Stuff(ListNumber,1,Charindex('-',ListNumber),''))

  使用LIKE进行模糊查询

  LIKE运算符用于匹配字符串或字符串的一部分(称为子串),由于该运算符只用于字符串,所以仅与Char或Varchar数据类型联合使用。

  在数据更新、删除或者查询的时候,依然可以使用LIKE关键字来进行匹配查找,例如:

  SELECT * FROM Students WHERE SName LIKE '张%'

  使用BETWEEN在某个范围内进行查询

  使用关键字BETWEEN可以查找那些介于两个已知值之间的一组未知值。要实现这种查找必须知道开始查找的初值和终值,这个最大值和最小值用单词AND分开,例如:

  SELECT * FROM SCore WHERE Score BETWEEN 60 AND 80

  此外,BETWEEN查询日期范围的时候使用得比较多,例如:查询不在1992年8月1号到1993年8月1号之间订购的读书列表。

  SELECT * FROM Sales WHERE ord_date NOT BETWEEN '1992-8-1' AND '1993-8-1'

  提示:使用NOT来对限制条件“取反”操作

  使用IN在列举值内进行查询

  查询的值是指定的某些值之一,可以使用带列举值的IN关键字来进行查询。

  例如:列举值放在圆括号里,用逗号分开。

  SELECT SName AS 学员姓名 FROM Students WHERE SAddress IN ('北京','广州','上海') ORDER BY SAddress SQL Server中的聚合函数

  在查询中还会经常碰到的要求是取某些列的最大值、最小值、平均值等信息,有时候还需要计算出究竟查询到多少行数据项。这个时候就可以使用聚合函数了,聚合函数能够基于列进行计算,并返回单个值。

  SQL Server提供了以下几个聚合函数:

  1.SUM

  SUM返回表达式中所有数值的总和,它只能用于数字类型的列。

  例如:在Pubs数据库中,要得到商务付款的总数,执行以下查询语句。

  SELECT SUM(ytd_sales) FROM titles WHERE type = 'business'

  注意:这种查询只返回一个数值,因此,不能够直接与可能返回多行的列一起使用来进行查询。

  2.AVG

  AVG函数返回表达式中所有数值的平均值,也只能用于数字类型的列。

  例如:要查询及格线以上的学员的平均成绩。

  SELECT AVG(SCore) AS 平均成绩 FROM Score WHERE Score >=60

  3.MAX和MIN

  MAX返回表达式中的最大值,MIN返回表达式的最小值,它们都可以用于数字型、字符型以及日期/时间类型的列。

  例如:查询平均成绩、最高分、最低分的语句如下。

  SELECT AVG(SCore) AS 平均成绩,MAX(Score) AS 最高分,MIN(Score) AS 最低分 FROM Score WHERE Score >=60

  4.COUNT

  COUNT返回提供的表达式中非空值的计数,COUNT可以用于数字和字符类型的列。

  例如:查询及格人数的语句如下。

  SELECT COUNT(*) AS 及格人数 FROM Score WHERE Score >= 60 分组查询

  使用Group By进行分组查询

  成绩表中存储了所有课程的成绩,在这种情况下,可能就需要统计不同课程的平均成绩。也就是说,需要对不同的成绩首先按照课程来进行分组,分组以后再进行聚合计算,得到累计信息。

  采用分组查询实现的SQL语句如下:

  SELECT CourseID, AVG(Score) AS 课程平均成绩 FROM Score GROUP BY CourseID

  使用HAVING子句进行分组筛选

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何通过PHP编写一个简单的在线预约系统如何通过PHP编写一个简单的在线预约系统Sep 26, 2023 pm 09:55 PM

如何通过PHP编写一个简单的在线预约系统随着互联网的普及和用户对便利性的追求,在线预约系统越来越受到欢迎。无论是餐厅、医院、美容院还是其他服务行业,都可以通过一个简单的在线预约系统来提高效率并为用户提供更好的服务体验。本文将介绍如何使用PHP编写一个简单的在线预约系统,并提供具体的代码示例。创建数据库和表格首先,我们需要创建一个数据库来存储预约信息。在MyS

快速入门:使用Go语言函数实现简单的图书管理系统快速入门:使用Go语言函数实现简单的图书管理系统Jul 30, 2023 am 09:18 AM

快速入门:使用Go语言函数实现简单的图书管理系统引言:随着计算机科学领域的不断发展,软件应用的需求也越来越多样化。图书管理系统作为一种常见的管理工具,也成为很多图书馆、学校和企业必备的系统之一。在本文中,我们将使用Go语言函数来实现一个简单的图书管理系统。通过这个例子,读者可以学习到Go语言中函数的基本用法以及如何构建一个实用的程序。一、设计思路:我们首先来

如何使用PHP开发简单的文件管理功能如何使用PHP开发简单的文件管理功能Sep 20, 2023 pm 01:09 PM

如何使用PHP开发简单的文件管理功能简介:文件管理功能在很多Web应用中都是必不可少的一部分。它允许用户上传、下载、删除和展示文件,为用户提供了便捷的文件管理方式。本文将介绍如何使用PHP开发一个简单的文件管理功能,并提供具体的代码示例。一、创建项目首先,我们需要创建一个基本的PHP项目。在项目目录下创建以下文件:index.php:主页面,用于显示上传表

编写一个简单的计算器的C/C++程序编写一个简单的计算器的C/C++程序Sep 02, 2023 pm 10:49 PM

简单计算器是执行一些基本运算的计算器,例如“+”、“-”、“*”、“/”。计算器可以快速完成基本操作。我们将使用switch语句来制作一个计算器。示例Operator−‘+’=>34+324=358Operator−‘-’=>3874-324=3550Operator−‘*’=>76*24=1824O

如何使用PHP编写一个简单的网络爬虫如何使用PHP编写一个简单的网络爬虫Jun 14, 2023 am 08:21 AM

网络爬虫是一种自动化程序,能够自动访问网站并抓取其中的信息。这种技术在如今的互联网世界中越来越常见,被广泛应用于数据挖掘、搜索引擎、社交媒体分析等领域。如果你想了解如何使用PHP编写简单的网络爬虫,本文将会为你提供基本的指导和建议。首先,需要了解一些基本的概念和技术。爬取目标在编写爬虫之前,需要选择爬取的目标。这可以是一个特定的网站、一个特定的网页、或整个互

MySQL表设计指南:创建一个简单的员工考勤表MySQL表设计指南:创建一个简单的员工考勤表Jul 01, 2023 pm 01:54 PM

MySQL表设计指南:创建一个简单的员工考勤表在企业管理中,员工的考勤管理是至关重要的一项任务。为了准确记录和统计员工的考勤情况,我们可以利用MySQL数据库来创建一个简单的员工考勤表。本篇文章将指导您如何设计和创建这个表,并提供相应的代码示例。首先,我们需要确定员工考勤表所需的字段。一般来说,员工考勤表至少需要包含以下字段:员工ID、日期、上班时间、下班时

如何通过C++编写一个简单的扫雷游戏?如何通过C++编写一个简单的扫雷游戏?Nov 02, 2023 am 11:24 AM

如何通过C++编写一个简单的扫雷游戏?扫雷游戏是一款经典的益智类游戏,它要求玩家根据已知的雷区布局,在没有踩到地雷的情况下,揭示出所有的方块。在这篇文章中,我们将介绍如何使用C++编写一个简单的扫雷游戏。首先,我们需要定义一个二维数组来表示扫雷游戏的地图。数组中的每个元素可以是一个结构体,用于存储方块的状态,例如是否揭示、是否有雷等信息。另外,我们还需要定义

如何通过PHP编写一个简单的在线点评系统如何通过PHP编写一个简单的在线点评系统Sep 24, 2023 am 09:25 AM

如何通过PHP编写一个简单的在线点评系统引言:随着互联网的发展,人们对于网上购物和餐饮点评的需求越来越大。本文将介绍如何通过PHP编写一个简单的在线点评系统来满足用户的需求。文章将包括系统的总体设计和具体的PHP代码实例。一、系统总体设计:数据库设计:在线点评系统需要存储用户信息、商品信息和点评信息等数据。因此,我们需要设计相应的数据库表来存储这些信息。以下

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前By尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),