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.姓名="邓倩梅")

时间: 2024-10-10 00:34:10

MySQL 之 扩展例子的相关文章

PHP安装mysql.so扩展

在PHP中mysql_connect模块已经逐渐被弃用,我在搭建环境时也没有再安装mysql扩展,但是今天在维护一个老项目时,出现报错 Fatal error: Uncaught Error: Call to undefined function mysql_connect() 于是google一下,发现如果php和mysql都已经安装完成了,可以使用phpize工具手动编译生成mysql.so扩展来解决 下面是操作步骤:1.进入php源码的ext/mysql目录 cd /usr/local/s

九周第四次课(2月26日) 11.1 LAMP架构介绍 11.2 MySQL、MariaDB介绍 11.3/11.4/11.5 MySQL安装 扩展 mysql5.5源码编译安装

11.1 LAMP架构介绍11.2 MySQL.MariaDB介绍11.3/11.4/11.5 MySQL安装扩展mysql5.5源码编译安装   http://www.aminglinux.com/bbs/thread-1059-1-1.html mysql5.7二进制包安装(变化较大)  http://www.apelearn.com/bbs/thread-10105-1-1.html =====================================================

如何在PHP7中安装mysql的扩展

相对与PHP5,PHP7的最大变化之一是移除了mysql扩展,推荐使用mysqli或者pdo_mysql,实际上在PHP5.5开始,PHP就着手开始准备弃用mysql扩展,如果你使用mysql扩展,可能看到过这样的提示"Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in".所以在以后的程

用Jasper Report制作Mongodb join Mysql的报表例子

多样性和多数据源问题使用JasperReport等报表工具本身不易处理,比如展现MongoDB和mysql的混合运算.虽然JasperReport/Birt有virtual data source或table join等功能,但只在商业版或高端版本出现,在免费版中实现难度很大,而且功能也有较大局限,无法对连接后的数据进行类似SQL的结构化计算. 集算器具有结构化强计算引擎,支持多样性数据源,集成简单,可以协助报表工具方便地实现此类需求.下面通过一个例子来说明MongoDB join mysql的

AJAX调用mysql数据库简单例子

<html>       <head>       </head>       <body>          <form action="7.php">        地址:<input type="text" name="addr" value="localhost"> 用户:<input type="text" name=&

mysql+ssh整合例子,附源码下载

项目引用jar下载:http://download.csdn.net/detail/adam_zs/7262727 项目源码下载地址:http://download.csdn.net/detail/adam_zs/7262749 今天花时间把ssh整合了一下,重新再学习一下,希望对大家有所帮助! 我用的是mysql数据库,建表语句比较简单就不贴出来了,建表的时候记的设置id为自动增加哦. 项目文件位置,项目引用jar包 项目配置文件 web.xml <?xml version="1.0&q

Java操作mysql数据库简单例子

package com.Jdbc.demo; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import com.mysql.jdbc.Connection; public class jdbc02 { public static final String url = "jdbc:mysql://localhost:3306/school?useUnicode=true&a

mysql基本操作扩展

约束: not null:非空约束,指定某列不为空 unique: 唯一约束,指定某列和几列组合的数据不能重复 primary key:主键约束,指定某列的数据不能重复.唯一 foreign key:外键,指定该列记录属于主表中的一条记录,参照另一条数据 check:检查,指定一个表达式,用于检验指定数据 Not null create table  temp( id int not  null, name varchar(255)  not null default 'abc', sex ch

memcached +mysql+php 测试例子

最近看了看memcached 缓存 mysql,经过一段时间的研究·把自己测试方法写出来,给像我一样的初学者用~我的环境是 nginx + php-fpm + apc + mysql 编译安装memcached tar zxvf memcached-1.4.0.tar.gzcd memcached-1.4.0./configure --prefix=/usrmakemake install 启动memcached memcached -d -m 64 -u root -l 192.168.6.1