MySQL 之 扩展例子
扩展例子
插入一条记录
INSERT INTO 表名 [(字段1,…,字段n)] VALUES (值1,…,值n)
插入查询的结果
INSERT INTO 表名 (字段1,…,字段n) VALUES 子查询
例如:INSERT INTO Scores VALUES ("990301", "大学计算机基础", 98)
DELETE FROM 表 [WHERE 条件]
注意: WHERE子句缺省,则删除表中所有的记录(表还在)
例如::DELETE FROM Scores WHERE 成绩<70
UPDATE 表 SET 字段1=表达式1, … ,字段n=表达式n [WHERE 条件]
注意: WHERE子句缺省,则修改表中所有的记录
例 将表Students中学生王涛的姓名改为王宝球
UPDATE Students SET 姓名=“王宝球” WHERE 姓名="王涛"
例 将表Students中助学金低于200的学生加30元
UPDATE Students SET 助学金=助学金+30 WHERE 助学金<200
UPDATE语句一次只能对一个表进行修改
选择字段:
例7.10 查询所有的专业,查询结果中不出现重复的记录
SELECT DISTINCT 专业 FROM Students;
例7.11 使用合计函数,查询学生人数、最低助学金、最高助学金和平均助学金
SELECT Count(*) AS 人数, Min(助学金) AS 最低助学金, Max(助学金) AS 最高助学金, Avg(助学金) AS 平均助学金
FROM Students
例7.12 查询学生的姓名和年龄
SELECT 姓名, Year(Date())-Year(出生年月) AS 年龄 FROM Students
选择记录:
例7.13 显示所有非计算机专业学生的学号、姓名和年龄
SELECT 学号, 姓名, Year(Date())-Year(出生年月) AS 年龄 FROM Students WHERE 专业<>"计算机"
例7.14 查询1981年(包括1981年)以前出生的女生姓名和出生年月。
SELECT 姓名,出生年月 FROM Students WHERE 出生年月 < #1/1/1982# AND 性别="女"
排序:
例7.15 查询所有党员学生的学号和姓名,并按助学金从小到大排序。
SELECT 学号, 姓名 FROM Students WHERE 党员=True ORDER BY 助学金
可用多个关键字排序。例如,ORDER BY 专业 ASC, 助学金 DESC
ASC:表示升序,DESC:表示降序。
分组查询:
例7.16 查询每个专业学生人数。(简单分组)
SELECT 专业, count(*) AS 人数 FROM students GROUP BY 专业;
例7.17 查询各专业男女生的平均助学金(复杂分组)
SELECT 专业,性别, Avg(助学金) AS 平均助学金 FROM Students GROUP BY 专业, 性别
将专业和性别都相同的记录分在一组。
例7.18 对Scores表查询有2门课程成绩在75以上的学生的学号和课程数。分组后过滤
SELECT 学号, Count(*) AS 课程数 FROM Scores WHERE 成绩>=75 GROUP BY 学号
HAVING Count(*)>=2
连接查询:
例7.19 查询所有学生的学号、姓名、课程和成绩
SELECT Students.学号,Students.姓名,Scores.课程, Scores.成绩 FROM Students, Scores
WHERE Students.学号 = Scores.学号
自动生成语句:
SELECT Students.学号, Students.姓名, Scores.课程, Scores.成绩 FROM Students INNER JOIN Scores ON Students.学号 = Scores.学号
例7.20 查询选修了“高等数学”课程的学生的学号、姓名和成绩。
SELECT Students.学号, Students.姓名, Scores.成绩 FROM Students, Scores
WHERE Students.学号=Scores.学号 AND Scores.课程="高等数学"
上述语句可以改写为:
SELECT Students.学号, Students.姓名, Scores.成绩 FROM Students INNER JOIN Scores
ON Students.学号 = Scores.学号 WHERE Scores.课程="高等数学"
嵌套查询:在SQL中,将一个SELECT语句查询块嵌套在另一个SELECT语句的WHERE子句或HAVING子句中称为嵌套查询
例7.21 查询没有学过大学计算机基础的学生的学号、姓名和专业
SELECT Students.学号, Students.姓名, Students.专业 FROM Students
WHERE Students.学号 Not in
(SELECT Scores.学号 FROM Scores WHERE Scores.课程="大学计算机基础")
例7.22 查询与“邓倩梅”在同一个专业的学生的学号和姓名
SELECT Students.学号, Students.姓名 FROM Students WHERE 专业 in
(SELECT Students.专业 FROM Students WHERE Students.姓名="邓倩梅")
MySQL 之 扩展例子的更多相关文章
- PHP安装mysql.so扩展
在PHP中mysql_connect模块已经逐渐被弃用,我在搭建环境时也没有再安装mysql扩展,但是今天在维护一个老项目时,出现报错 Fatal error: Uncaught Error: Cal ...
- mysql定时任务简单例子
mysql定时任务简单例子 ? 1 2 3 4 5 6 7 8 9 如果要每30秒执行以下语句: [sql] update userinfo set endtime = now() WHE ...
- mysql触发器的例子--插入前更新数据
本文介绍下,一个mysql触发器的例子,在数据插入前更新相关内容,有需要的朋友参考下. mysql触发器的例子,如下: view source print? 001 mysql> CREATE ...
- mysql空间扩展 VS PostGIS
http://www.cnblogs.com/LBSer/p/3629149.html 功能 Mysql spatial extension PostGIS 空间索引 仅MyISAM支持R树索引,I ...
- php添加mysql.so扩展
1.软件包安装 yum install php-mysql 安装的是mariadb的扩展 yum install php-mysqlnd 安装的是mysql的扩展
- PHP安装mysql.so扩展及相关PHP.ini 配置参数说明
在PHP中mysql_connect模块已经逐渐被弃用,我在搭建环境时也没有再安装mysql扩展,但是今天在维护一个老项目时,出现报错 Fatal error: Uncaught Error: Cal ...
- Java中连接MySql数据库的例子
Java中连接MySql数据库的例子: package com.joinmysql.demo; import java.sql.DriverManager; import java.sql.Resul ...
- MySQL索引扩展(Index Extensions)学习总结
MySQL InnoDB的二级索引(Secondary Index)会自动补齐主键,将主键列追加到二级索引列后面.详细一点来说,InnoDB的二级索引(Secondary Index)除了存储索引列k ...
- 【译】Spring 4 + Hibernate 4 + Mysql + Maven集成例子(注解 + XML)
前言 译文链接:http://websystique.com/spring/spring4-hibernate4-mysql-maven-integration-example-using-annot ...
随机推荐
- MySQL 优化1
系统在应用时间很长的情况下会慢慢变得很慢,无论是人还是机器为了更好的工作和学习都需要适当学习.数据库也是一样的用久了, 自然就会产生空间碎片,需要我们都i数据库中的数据块进行维护和整理.下面以实例来说 ...
- 如何学习CCIE
想想自己拖了这么久,也没考试,也没积极去做实验,心里也有怨念,其实一直是方法不对,今天心里产生共鸣,后悔当初太年轻. 转载地址:http://bbs.hh010.com/thread-467553-1 ...
- [转]C#中的结构体与类的区别
C#中的结构体与类的区别 经常听到有朋友在讨论C#中的结构与类有什么区别.正好这几日闲来无事,自己总结一下,希望大家指点. 1. 首先是语法定义上的区别啦,这个就不用多说了.定义类使用关键字cla ...
- 在java项目中使用protobuf
1 通用方式 第一步,定义数据结构 第二步,使用protoc.exe生成java代码 第三步,序列化 第四步,反序列化 2 grpc方式 grpc官方推荐的方式,通过maven插件来生成java代码. ...
- JavaScript演示如何访问Search字段
<!DOCTYPE html> <html> <body> <h3>演示如何访问Search字段</h3> <input type=& ...
- 修正IE6中FIXED不能用的办法,转载
.fixed-top /* 头部固定 */{position:fixed;bottom:auto;top:0px;} .fixed-bottom /* 底部固定 */{position:fixed;b ...
- 借助node.js + mysql 学习基础ajax~
很多小白不知道ajax怎么学,所以就弄了个node后台模拟下基本的ajax请求. 环境要求是安装node~ 先上linkMysql.js var mysql = require('mysql') va ...
- SQL语句编写注意问题
下面就某些SQL语句的where子句编写中需要注意的问题作详细介绍.在这些where子句中,即使某些列存在索引,但是由于编写了劣质的SQL,系统在运行该SQL语句时也不能使用该索引,而同样使用全表扫描 ...
- Contiki 2.7 Makefile 文件(二)
二.Makefile.include 1.第一部分 (1) ifndef CONTIKI ${error CONTIKI not defined! You must specify where Con ...
- 搭建LoadRunner中的场景(二) 集合点
Rendezvous: 这个单词来自于法语,军队集合的意思.LoadRunner中是指各虚拟用户在同一时刻完成指定的操作. 一. 集合点设置步骤 1. 在脚本中需要测试并发性能的操作之前加入集合点. ...