第7章数据库及表操作
第7章 MySQL数据库基础
7.1.2 MySQL服务器的安装与配置 服务器的安装与配置
MySQL服务器的安装: (1)下载Windows版的MySQL,双击下载文件进入安装向导。有3种安装方 式可供选择:Typical(典型安装)、Complete(完全安装)和Custom(定制安 装),如图7.2所示。对于大多数用户,选择Typical就可以了。单击【Next】按钮 8 MySQL命令行
7.1.3 MySQL的环境 的环境
2. 重新配置服务器 如果要对服务器重新配置,可以打开“开始”→“程 序”→“MySQL”→“MySQL Server 5.1”→“MySQL Server Instance Configure Wizard”菜单项,在出现的配置向导中重新配置服务器。 3. 选项文件 在C:\Program Files\MySQL\MySQL Server 5.1的MySQL主目录下有一个my.ini 文件,这是MySQL的选项文件,MySQL启动时会自动加载该文件中的一些选项。 可以通过修改选项文件来修改MySQL的一些默认设置。 4. 数据目录 MySQL有一个数据目录,用于存放数据库文件。在MySQL 5.1中,数据目录 的默认路径为C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server 5.1\data。在data目录中MySQL为每个数据库建立一个文件夹,所有的表文 件存放在相应的数据库文件夹中。
图7.2 MySQL安装模式选择
7.1.2 MySQL服务器的安装与配置 服务器的安装与配置
(2)进入如图7.3所示的安装界面。在MySQL 5.1中,数据库主目录和文件 目录是分开的。其中,“Destination Folder”为MySQL所在的主目录,默认为 C:\Program Files\MySQL\MySQL Server 5.1。“Data Folder”为MySQL数据库文件 和表文件所在的目录,默认为C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server 5.1\data,其中Application Data是隐藏文件夹。确认后 单击【Install】按钮开始安装。 (3)等待一段时间后安装完成,在弹出的窗口中单击【Next】按钮完成安装。
《数据库》第七章 基本SQL查询
8
Inspur Education
从表中选择多个列
要查看数据库中所有图书的名称和出版日期
SELECT bookname,pubdate
5
Inspur Education
选择表中的所有数据
显示客户customers表中所有的数据
SELECT * FROM books;
在SELECT后面键入*号
6
Inspur Education
从表中选择一列 2-1
在Oracle中,可以只在结果中返回特定的列。SELECT语 句中选择特定列被称为“投影(projection)”。可以 选择表中的一列,也可以选择多个列或者是所有的列。
示例:查询所有BOOKNAME列以“j”开头的书本。
SELECT * FROM books WHERE bookname LIKE 'j%';
17
Inspur Education
WHERE子句——连接运算符
在WHERE子句中可以使用连接运算符将各个表达式关联起 来,组成复合判断条件。常用的连接运算符有AND和OR。
INSERT INTO books (isbn, bookname, pubdate, quantity, bcost, bretail, bcategory)
VALUES (2, 'a语言', to_date('2017-10-8', 'yyyy-mm-dd'), null, '40', '68', 'computer');
数据库第7章-数据库设计(2)-概念结构设计作业
例 一个企业应用包括人员管理、生产管理、设 备管理等功能模块。其中: 人员管理 一个职工工作于一个部门,一个部门有若干职 工。对于部门应记录各部门的编号、部门名称、 负责人、电话等信息。
设计局部E-R模型 ——设备管理的E-R图 设备管理部门要记录设备处的编号、负责 人和电话,设备处工作人员的职务、年龄、 职工编号、姓名和性别;设备处管理设备 的编号,名称和价格以及零件的编号、名 称、规格,还包括设备的装配日期和使用 的零件数量。 一个设备处有若干名职工管理若干台设备, 一个设备由多种零件组成,一个零件可以 使用在多种设备上。
设计局部E-R模型 ——生产管理的E-R图 生产管理部门要保存该生产部门的编号、 名称、负责人和电话,生产处工作人员的 职务、年龄、职工编号、姓名和性别;生 产处生产零件的编号,名称和规格,还包 括零件的生产日期和零件数量。 一个生产处有若干名职工管理生产多种零 件。
第7章 数据库数据查询
[ HAVING search_condition]
[ ORDER BY order_expression [ ASC|DESC ] ]
• 参数说明如下。
SELECT子句:指定由查询结果返回的列。
INTO子句:将查询结果存储到新表或视图中。 FROM子句:用于指定数据源。 WHERE子句:指定用于限制返回的行的搜索条件。 GROUP BY子句:指定用来放置输出行的组,并
FROM stu_info
在指定列查询中,列的显示顺序由SELECT子句指 定,与数据在表中的存储顺序无关;同时,在查询 多列时,用“,”将各字段隔开。
• 2.查询所有列
除了能够进行指定列查询以外,使用SELECT语
句还可以查询表中的所有列,这是通过星号(*) 通配符实现的。使用“*”通配符,查询结果将列 出表中所有列的值,而不必指明各列的列名,这 在用户不清楚表中各列的列名时非常有用。服务
• 【例7-5】查询所有的院系信息。
SELECT DISTINCT sdept FROM stu_info 在使用DISTINCT关键字后,去除的是SELECT子 句查询的列的重复信息。如果SELECT子句查询
的列为多列,那么只有这些列的信息同时重复的
记录才被去除;另外,如果表中有多个为NULL的 数据,服务器会把这些数据视为相等。
且如果SELECT子句select_list中包含聚合函数,则
计算每组的汇总值。
• HAVING子句:指定组或聚合函数的搜索条件。
HAVING通常与GROUP BY子句一起使用。 ORDER BY子句:指定结果集的排序方式。ASC 关键字表示升序排列结果,DESC关键字表示降序 排列结果。如果没有指定任何一个关键字,那么 ASC就是默认的关键字。如果没有ORDER BY子 句,DBMS将根据输入表中数据的存放位置来显示 数据。 在这一系列的子句中,SELECT子句和FROM子句 是必需的,其他的子句根据需要都是可选的。
数据库课程课件_第7章_数据库设计
数据字典是在需求分析阶段建立,并在数据库设计过程中不 断改进、充实和完善。
⑴ 数据项:
数据项是数据的最小单位。
数据项描述={数据项名,含义说明,类型,长度,取值范围, 与其它数据项的逻辑关系} ⑵ 数据结构: 数据结构反映了数据之间的组合关系。
数据结构描述={数据结构名,含义说明,组成,{数据项或数据结
本章特点:实用性较强。
§1、 数据库设计概述 数据库设计是指对于一个给定的应用环境,提供一 个确定最优数据模型与处理模式的逻辑设计,以及一个
确定数据库存储结构与存取方法的物理设计,建立起既
能反映现实世界信息和信息联系,满足用户数据要求和 加工要求,又能被某个数据库管理系统所接受,同时能 实现系统目标,并有效存取数据的数据库。
3、数据流图和数据字典
数据流图DFD有四个基本成分: 用箭头表示数据流、用圆圈表示加工或处理, 用双线段表示文件、用方框表示外部实体。
9页
学籍管理数据流图
毕业证书 新生名单 体检表
毕业登记表
宿舍描述
学生档案
毕业登记表
毕业生名单
录取通知
报到证
学生
1.0
2.0
学生基 本情况
3.0
报
到 招生 办公室
同意/不同意 接受 核对通知书 体检结果
审 核
9页
ቤተ መጻሕፍቲ ባይዱ
成绩单 教室安排
课程管理 数据流图
教材 教室
选 用 教 材 教 室 安 排 课 程 介 绍
学 生
教师 课程
任 课 教 师 介 绍
考 场 试 卷 成 绩
考 场 安 排
试 卷
成 绩
《Access2016数据库教程》第7章报表
节。一般在组页眉中显示和输出用于分组的字段的值,在 组页脚中添加计算型控件,对同组记录的数据汇总和显示 输出。
【例7-8】在“学生成绩管理”数据库中,基于“例7-4学生清单 (报表设计)”设计一个按“院系代码”分组的报表,并要求 统计各院系学生的人数,报表名称为“例7-8 统计各院系学生 人数报表”。
7.2.2 使用“空报表”按钮创建报表
❖ 类似于用“空白窗体”创建窗体。启动一个空报表, 自动打开一个“字段列表”窗口
❖ 可以通过在“字段列表”窗口中双击字段或拖曳字 段,在设计界面上添加绑定型控件显示字段内容。
【例7-2】 在“学生成绩管理”数据库中,使用“空报表”按钮 创建一个报表,在该报表中能打印输出所有学生的学号、 姓名、选修的课程、该课程成绩和学分,并使输出的记录 按“学号”升序排列。报表名称为“例7-2学生选课成绩报表 (空报表)”。
7.1.1 报表的类型
提供了4种类型的报表 (1)纵栏式报表
每个字段都显示在主体节中的一个独立的行上,并且左边 带有一个该字段的标题标签。 (2)表格式报表 以行和列的方式输出数据,一个记录的所有字段显示在一 行。 (3)图表报表 报表中的数据以图表格式显示,类似Excel中的图表。 (4)标签报表 是一种特殊类型的报表,用来邮寄学生的通知、信件等。
7.3.3 报表中添加日期时间和页码
❖ “报表”和“报表向导”生成的报表中,系统自动 在页脚处生成显示日期和页码的文本框控件。
❖ 自定义生成的报表,可通过系统提供的“日期和时 间”对话框添加日期和时间。
❖ 添加计算控件:添加文本框,将“控件来源”属性 设置为日期、时间或者页码的表达式。如设置为 “=Date( )”、“=Time( )”、“=[Page]”,(报 表的当前页码) “=[Pages]”(报表的总页码数)。
Ch07 数据库基础
7
第7章 数据库基础 章
表 7.3 常用的查询条件
查询条件 比较 确定范围 确定集合 字符匹配 空值 多重条件
谓
词
=, >, <, >=, <=, !=, <>, !>, !<, NOT+以上比较运算符 BETWEEN AND, NOT BETWEEN AND IN, NOT IN LIKE, NOT LIKE IS NULL, IS NOT NULL AND, OR
DataSet
DataAdapter
数据源
图 7.11 DataSet、DataAdapter 和数据源之间的关系
22
第7章 数据库基础 章
图 7.12 DataSet 类的层次结构
23
第7章 数据库基础 章
表 7.6 DataRowState 枚举值
值 Added Deleted Detached Modified Unchanged
20
第7章 数据库基础 章
Dim strQuery As String = "Select * From PhoneBook" Dim thisCommand As OleDbCommand = New OleDbCommand(strQuery, thisConnection) Dim dr As OleDbDataReader = thisCommand.ExecuteReader() Do While dr.Read Debug.Print(dr.Item(1)) Loop
Imports System.Data.OleDb '引入提供程序的命名空间 引入提供程序的命名空间 Dim csb As OleDbConnectionStringBuilder = New OleDbConnectionStringBuilder() csb.Provider = "Microsoft.Jet.OLEDB.4.0" csb.DataSource = strDB 'strDB 为 Access 数据库的绝对路径 Dim conn As String = csb.ConnectionString '获取连接字符串 获取连接字符串 Dim thisConnection As OleDbConnection = New OleDbConnection(conn) thisConnection.Open() '连接到数据源 连接到数据源
数据库第7章-数据库设计(2)-概念结构设计
第七章 数据库设计
7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 数据库设计概述 需求分析 概念结构设计 逻辑结构设计 数据库的物理设计 数据库实施 数据库运行与维护 小结
需求分析阶段
调查 机构 情况
熟悉 业务 活动
明确 用户 需求
确定 系统 边界
分析 系统 功能
分析 系统 数据
编写 分析 报告
概念 设计 阶段
数据 流程图 DFD
数据库 设计人员
用户
数据 字典 DD
7.3 概念结构设计
什么是概念结构设计
需求分析阶段描述的用户应用需求是现实世界 的具体需求 将需求分析得到的用户需求抽象为信息结构即
概念模型的过程就是概念结构设计
概念结构是各种数据模型的共同基础,它比数
性别
分配
1
住房
设计分E-R图的步骤
(1)以数据字典为出发点定义E-R图。
实体与属性是相对而言的。
同一事物,在一种应用环境中作为“属性”, 另一种应用环境中就必须作为“实体”。 例: 学 校 中 的 系 , 在 某 种 应 用 环 境 中 , 它 只 是 作为 “学生”实体的属性,表明学生属于哪个系; 另一种环境中,由于需要考虑一个系的系主任、
教师人数、学生人数、办公地点等,这时它就需
“is member of”
张英
王平
刘勇
……
赵斌
2. 聚集(Aggregation)
定义某一类型的组成成分 它抽象了对象内部类型和成分之间“is part of”的语义 在E-R模型中若干属性的聚集组成实体型,就是这种抽象
实体型
学 生
第7章 数据库高级对象的使用
3、视图的优点
1.视点集中 用户只关心它感兴趣的某些特定数据和他们所负责的特定任务。
2.简化操作 视图大大简化了用户对数据的操作。因为在定义视图时,若视图本身就 是一个复杂查询的结果集,这样在每一次执行相同的查询时,不必重新 写这些复杂的查询语句,只要一条简单的查询视图语句即可。可见视图 向用户隐藏了表与表之间的复杂的连接操作。
SCHEMABINDING | VIEW_METADATA }
2、用SQL语句定义视图
【例7-1】已知学生表的数据如图7-1所示。
创建一个视图,视图中只包含信安152班的数据,SQL语 句如下: CREATE VIEW VW_信安152 AS SELECT * FROM 学生 WHERE 班级='信安152' 通过Select语句查询视图中的数据,语句如下: SELECT * FROM VW_信安152
运行程序过程: EXEC prcShopper '000002' /*返回ID号为000002的购物者所购买的 玩具及数量。*/
提示:存储过程可以带多个输入参数,之间用逗号格开。
二、存储过程
RETURN语句从一个存储过程返回值
【例7-8】带输入参数的存储过程,并且报告执行的结果,根据输入的购物者的ID号, 返回购物者的名字、所订购的玩具的名字和订购数量。 CREATE PROCEDURE prcShopper1 @ShopperId CHAR(6) AS BEGIN
JOIN Toys ON OrderDetail.cToyId = Toys.cToyId END
调用该存储过程方法是:
EXEC prcOrders
/*运行(调用)存储过程*/
二、存储过程
第7章 数据的插入、修改与删除操作
16
03
数据删除/使用DELETE删除表数据
【例7-11】删除course表中cdept的值为‘信息学院’的记录。 DELETE FROM jxgl.course WHERE cdept='信息学院';
DELETE语句中如果不加上“WHERE条件表达式”,数据库系统会删除指定表中的所有数据。请谨慎使 用。
7
01
数据插入/为表的指定字段插入数据
【例7-5】向course表的cno,cname和ccredit字段插入数据。INSERT 语句中,这3个字段的顺序可以任意排列。 INSERT语句如下:
INSERT INTO jxgl.course (cno, ccredit, cname) VALUES('11110930','2',' 电子商务');
20
04
MERGE INTO
【例7-13】下面的例子把T1表中C1值为2的记录行中的C2列,更新为 表T2中C3值为2的记录中C4列的值,同时把T2中C3列为4的记录行插入 到T1中。 CREATE TABLE T1 (C1 INT, C2 VARCHAR(20)); CREATE TABLE T2 (C3 INT, C4 VARCHAR(20)); INSERT INTO T1 VALUES(1,'T1_1'); INSERT INTO T1 VALUES(2,'T1_2'); INSERT INTO T1 VALUES(3,'T1_3'); INSERT INTO T2 VALUES(2,'T2_2'); INSERT INTO T2 VALUES(4,'T2_4'); COMMIT;
第7章数据库基础与Access2010—3
1. Access数据库 Access是Microsoft Office办公自动化套装软件中的一个 重要组成部分,是一种基于Windows平台的关系数据库 管理系统(RDBMS)。 Access界面友好、操作简单、功能全面、使用方便。是 典型的新一代桌面数据库管理系统。 Access主要适用于中小型应用系统,或作为客户机/服务 器系统中的客户端数据库。
第2页
3. Oracle数据库 Oracle是美国Oracle公司研制的一种关系型数据库管理 系统,是一个协调服务器和用于支持任务决定型应用程序 的开放型RDBMS。 它可以支持多种不同的硬件和操作系统平台,从台式机到 大型和超级计算机,为各种硬件结构提供高度的可伸缩性 ,支持对称多处理器、群集多处理器、大规模处理器等, 并提供广泛的国际语言支持。 Oracle属于大型数据库系统,主要适用于大、中小型应用 系统,或作为客户机/服务器系统中的服务器端的数据库 系统。
第5页
6. Sybase数据库 Sybase是美国Sybase公司研制的一种关系型数据库系统 ,是典型的UNIX或WindowsNT平台上客户机/服务器环 境下的大型数据库系统。 Sybase通常与Sybase SQL Anywhere用于客户机/服务 器环境,前者作为服务器数据库,后者为客户机数据库, 采用该公司研制的PowerBuilder为开发工具,在我国大 中型系统中具有广泛的应用。
三、Access 2010的数据库对象
Access2010中提供了六种数据对象,Access2010的主 要功能就是通过这六种数据对象来完成的。 1. 表 表(Table)是数据库中最基本的组成单位,是同一类数 据的集合体,是存储数据的单位。 2. 查询 查询(Query)最常用的功能是从表中检索特定的数据。 要查看的数据通常分布在多个表中,通过查询可以将多个 不同表中的数据检索出来,并在一个数据表中显示这些数 据。
第7章 数据库安全技术
录
网络安全管理的概念、目标及内容 网络面临的威胁及不安全因素 网络安全管理技术概念与模型 构建虚拟局域网VLAN实验 重点 教学目标 ● 理解数据库安全的概念及安全威胁 ● 掌握数据库的安全特性 ● 了解数据库的安全机制和策略 ● 理解数据库安全体系与防护技术 ● 掌握SQL Server2008用户安全管理实验
7.2 数据库安全威胁及隐患
2.数据库系统缺陷及隐患
数据库的安全缺陷和隐患要素包括: (1)DB应用程序的研发、管理和维护等人为因 素疏忽; (2)用户对数据库安全的忽视,安全设置和管理 失当; (3)部分数据库机制威胁网络低层安全; (4)系统安全特性自身存在的缺陷; (5)数据库账号、密码容易泄漏和破译; (6)操作系统后门及漏洞隐患; (7)网络病毒及运行环境等其他威胁。
7.1 数据库安全概述
3. 数据库管理系统的特性
数据库管理系统(DBMS)是建立、运用和维护数据库, 并进行统一管理和控制数据的系统。便于用户定义和操纵 数据,并保证数据的安全性、完整性、多用户对数据的并 发使用及发生故障后的数据库恢复等。DBMS由数据库和一 组管理数据的程序构成,是数据库系统的核心。 DBMS功能:提供数据访问与存取,并具有对数据库进 行建立、管理、维护等。可为用户或应用程序提供了访问 数据库中的数据和对数据的安全性、完整性、保密性、并 发性等进行统一控制的方法。特性:数据的安全性、结构 化、共享、独立性和可控冗余度。
7.2 数据库安全威胁及隐患
课堂讨论 1.威胁数据库安全的因素有哪些?缺陷和隐患主 要是什么? 2.攻击数据库的手段主要有哪些? 3.我国数据库安全的研究概况如何?
7.3 数据库的安全特性
7.3.1 数据库的安全性
1.数据库的安全性含义 数据库的安全性是指数据库中数据的保护措施,一 般包括用户的身份认证管理数据库的使用权限管理和数 据库中对象的使用权限管理三种安全性保护措施。 保障Web数据库的安全,构建一套安全的访问控 制模式,如图7-4所示。
数据库系统原理教程(第七章)清华大学
SYBASE关系数据库产品(续)
Sybase System 11.5 – SQLServer,关系数据库管理系统,专门负 责高速计算、数据管理、事务管理
ORACLE的Internet解决方案(续)
Oracle WebServer 2.0 增加了JAVA解释器和
LiveHTML解释器,使其能支持多种语言 由Web Request Broker(WRB), WebServer SDK 和 Webserver管理工具组成 – WRB是一个多线索多进程的HTTP服务器 – WebServer SDK 是一个开放的应用开发环境, 封装了WRB应用编程接口,允许用户使用 JAVA, LiveHTML, C++等web应用开发工 具
ORACLE工具(续)
Designer/2000 – CASE工具,帮助用户对复杂系统进行建模、 分析和设计 – 完成概要设计后,可以用来帮助绘制E-R 图、功能分层图、数据流图和方阵图,自动 生成数据字典、数据库表、应用代码和文档 – 由BPR, Modellers, Generators等组成
ORACLE工具(续)
Developer/2000(续) – ORACLE Forms 是快速生成基于屏幕的复 杂应用的工具,所生产的应用程序具有查询 和操纵数据的功能,可以现实多媒体信息, 具有GUI界面 – ORACLE Reprots是快速生产报表工具,如 普通报表、主从式报表、矩阵报表 – ORACLE Graphics是快速生产图形应用的 工具 – ORACLE Books用于生成联机文档
7. ORACLE的Internet解决方案
Oracle WebServer 1.0 主要由Oracle
WebListener, Oracle WebAgent和ORACLE7 服务器部分组成
第7章 数据库基础知识
教案讲稿第七章数据库基础知识[旧课复习]:复习内容:1.程序设计方法中常用方法。
2.结构化程序设计中三种基本结构。
复习目的:让学生巩固前一章节所学知识。
复习时长:大约5分钟。
[新课导入]:导入方式:复习Excel中数据操作,如排序、筛选、分类汇总导入目的:引出数据库及数据库管理系统等概念。
导入时长:大约5分钟[新课讲授]:重点:SQL语句中的insert、delect、update、select命令。
难点:查询语句select的筛选条件与分组统计。
方法:运用多媒体辅助教学,采用案例教学和任务驱动等教学法。
7.1 数据库系统的基本概念一、数据库基本概念1.数据数据(Data)实际上就是描述事物的符号记录。
计算机中的数据一般分为两部分:◆临时性数据:与程序仅有短时间的交互关系,随着程序的结束而消亡,一般存放于计算机内存中。
◆持久性数据:对系统起着长期持久的作用的数据,一般存放于计算机外存中。
数据结构:将多种相关数据以一定结构方式组合构成特定的数据框架,这样的数据框架称为数据结构。
2.数据库数据库(Database,DB)是数据的集合,它具有统一的结构形式并存放于统一的存储介质内,是多种应用数据的集成,并可被各个应用程序所共享。
数据库中的数据具有“集成”、“共享”的特点,即数据库集中了各种应用的数据,进行统一的构造与存储,从而使它们可被不同应用程序所使用。
3.数据库管理系统数据库管理系统(Database Management System,DBMS)是数据库的管理机构,它是一种系统软件,负责数据库中的数据组织、数据操纵、数据维护、控制及保护和数据服务等。
因此,数据库管理系统是数据库系统的核心且大多数DBMS 均为关系数据库系统。
4.数据库系统数据库系统(Database System,DBS)由如下5部分组成:•数据库(数据)•数据库管理系统(及其开发工具)•系统平台(软件)•硬件平台(硬件)•数据库管理员和用户(人员)这5个部分构成了一个以数据库为核心的完整的运行实体,称为数据库系统。
建库
7.2 数据库操作
【例7-3】创建一个名为student数据库。 1 其中主数据文件逻辑名为student_data1,物理名为student_data1.mdf, 初始大小为10MB,最大大小不受限制,每次增长1MB;存储在d:\student 文件夹下; 2 另外包含一个用户定义文件组fgroup1,在组中放置2个辅助数据文件。辅助 文件1的逻辑名为student_data2,物理名student_data2.ndf,初始大小为 5MB,最大大小为50MB,每次增长10%;辅助文件2的逻辑名为 student_data3,物理名student_data3.ndf,初始大小为5MB,最大大小 为50MB,每次增长10%;两文件均存储在d:\student下。 3 日志文件的逻辑名为student_log,物理文件名为student_log.ldf,初始 大小为1MB,最大大小不受限制,每次增长10%.存储在d:\student下。
CREATE DATABASE命令用来创建一个新数据库和存储该数据库的文件。 CREATE DATABASE的语法如下。 CREATE DATABASE数据库名 [ON {[PRIMARY]([NAME=数据文件的逻辑名,] FILENAME='数据文件的物理名' [,SIZE=文件的初始大小] [,MAXSIZE=文件的最大容量] [,FILEGROWTH=文件空间的增长量]) }[,. . .n]] [LOG ON {([NANE=日志文件的逻辑名,] FILENAME='逻辑文件的物理名' [,SIZE=文件的初始大小]) [,MAXSIZE=文件的最大容量] [,FILEGROWTH=文件空间的增长量]) }[, . . .n]]
7.2 数据库操作
第7章 MySQL数据库与结构化查询语言(SQL)
扬州大学计算机中心
8.2 PHP操作 操作MySQL方法详解 操作 方法详解
使用mysql_num_rows()函数获取查询结果集中的记录数 函数获取查询结果集中的记录数 使用
语句格式如下: 语句格式如下: Mysql_num_rows(resource result)
关闭数据库连接
语句格式如下: 语句格式如下: Mysql_close([resource link_identifier])
<<
<
>
>>
扬州大学计算机中心
8.2 PHP操作 操作MySQL方法详解 操作 方法详解
练习: 练习:
在上例的基础上,实现一个图书信息检索的功能, 在上例的基础上,实现一个图书信息检索的功能,界 面如下图所示。 面如下图所示。
<< < > >>
扬州大学计算机中心
8.2 PHP操作 操作MySQL方法详解 操作 方法详解
执行SQL语句 语句 执行
执行SQL的语句如下: 的语句如下: 执行 的语句如下 Mysql_query(string query[,resource link_identifier]) Query:字符串类型,传入的是 的指令。 :字符串类型,传入的是SQL的指令。 的指令 Link_identifier:MySQL服务器的连接标识。 服务器的连接标识。 : 服务器的连接标识 注意: 函数中执行的SQL语句不应以分号“;” 语句不应以分号“ 注意:在mysql_query()函数中执行的 函数中执行的 语句不应以分号 结尾。 结尾。
id Pub_time price author publisher
第7章 数据库基础
15
字段名称 学号 姓名 性别 出生日期 成绩
字段类型 文本 文本 文本 日期/时间 数字
字段大小 6 12 2
允许空值 必填 必填
其他要求 主键
单精度型
小数位: 1
16
① 打开 “学生管理.mdb”数据库。 ② 在“对象”窗格中选择“表”对象 。 ③选择“设计视图”一项。 ④ 设定字段 。 ⑤ 设定主关键字。 ⑥ 保存表的结构。 ⑦ 输入数据。
18
6.数据表的备份、删除、恢复和更名 这些操作类似于Windows中对文件或文件夹的操作。 7. 数据的排序: 单个字段排序 ; 多个字段排序。 8. 数据的筛选 在查看数据表时,往往需要在众多的记录中提取符合 某种条件的记录,即对数据表进行筛选。筛选记录一 共有4种方法,分别是:按选定内容筛选 ; 按窗体筛 选 ;按内容排除筛选;按高级筛选/排序
19
7.3.2 创建查询
查询是数据库最经常使用的一种操作。所谓查 询,就是根据给定的条件,从数据库的表中筛 选出符合条件的记录,构成一个数据集合。建 立一个查询后,可以将它看成一个简化的数据 表,作为构成窗体、报表的数据来源,也可以 以它为基础构成其他查询。
20
查询依据其对数据源操作方式和结果的不 同分为以下5种类型: 选择查询 参数查询 交叉表查询 操作查询 SQL查询
17
2. 修改数据表结构 若需要对字段名命名以及对数据类型、大小等进行修 改,就需要对表的结构进行修改。 3. 数据表数据的编辑 数据表结构创建与修改完成以后,还需要对数据表输 入数据或者修改数据,进行插入、修改、删除、排序 等操作,统称为数据表数据的编辑。 4. 表与表之间的关系 在实际的数据库中,一般存在多个表。数据表之 间的关系分为以下几种: 一对一关系; 一对多关系; 多对多关系 。 5.修改数据表之间的关系
数据库编程_第7章_多表查询_联接
结果集
buyer_name buyer_id Adam Barr Adam Barr Erin O’Melia Eva Corets Erin O’Melia Sean Chai 1 1 4 3 4 NULL
DEMO
列出所有教室的占用情况表 教室 教室名 上课时间段 课程名称 任课教 编号 称 师
4
DEMO
教室 编号 教室名 上课时间 称 段 课程名称 任课教 师
还没有安排班级上课的教室, 还没有安排班级上课的教室,不出现在报表中
select room.RoomID, ments, class.time, , from Room inner join class on Room.RoomID = class.RoomID inner join course on class.courseid = course.courseid inner join professor on class.professorid = professor.professorid order by Room.RoomID;
某列=表 某列 表1.某列 表2.某列 某列
从多个表中选择指定的列
从多个表中选择指定的列
JOIN关键字---指定被联接的表,以及如何联接 ON关键字---指定联接条件
查询两个或者多个表,产生一个结果集
使用主键和外键做为联接条件 如果一个表是复合主键,当联接表时必须在ON子句中 引用整个主键。 使用指定的表的共有列来联接表 如果联接表的列名相同,则必须使用表名做为前缀。
案例分析2—要求
一家银行发行了新的信用卡,刚开始的时候推广得很好 ,但是逐渐废卡也越来越多(卡上的余额少于2元,并 且用户长时间不使用该卡),因此银行在二月份把这些 少于2元的卡从都数据库表中删除了,但是很快问题就 来了,用户发现他的卡再也不能使用而投诉,因此只能 再把这些卡恢复。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第7章数据库及表操作本章要点掌握创建自由表方法与步骤,掌握表中数据输入方法与步骤,掌握表中数据的显示与修改的方法,掌握数据库的创建及使用方法,掌握数据库表的使用方法。
7.1 创建自由表7.1.1 表概述建立表时,首先要对所处理的对象进行调查分析,然后再根据需要设计一张二维表。
当表的行、列个数及每列中数据的属性确定后,再把数据集合在其中即可。
1.定义二维表名2.设计二维表的栏目3.填写二维表的内容4.定义表的结构在Visual FoxPro系统中,一张二维表对应一个数据表,称为表文件(Table)。
定义表的结构,就是根据二维表的定义来确定表的组织形式,也即定义表的字段个数、字段名、字段类型、字段宽度及是否以该字段建立索引等。
一张二维表由表名、表头、表的内容三部分组成,一个表则由表名、表的结构、表的记录三要素构成。
7.1.2 利用表设计器创建表打开“表设计器”有以下几种操作方法。
(1)在Visual FoxPro系统的主菜单下,打开“文件”菜单,选择“新建”命令,再选择“表”选项,按“新建”按钮,进入“表设计器”窗口。
(2)在“项目管理器”窗口,选择“数据”选项卡,单击“数据”左边的“+”,在展开的选项中,选择“表”选项,按“新建”按钮,进入“表设计器”窗口。
(3)使用Create命令。
命令格式:Create <表名>或:Create Table <表名> ([<字段名1>] 类型(长度)[, [<字段名2>] 类型(长度)……])命令功能:建立一个以<表名>为名的表。
7.1.3 利用表向导创建表在Visual FoxPro系统环境下,除使用“表设计器”创建表外,还可以用“表向导”创建表。
使用“表向导”创建表,就是把已有的表作为“样本”,在“向导”的引导下,通过筛选、修改等操作完成新表的创建。
7.1.4 表的打开与关闭表一旦创建完成,对表的操作可分为表结构的操作和表中记录的操作。
但是,无论对表作哪一种操作,首先要把表在当前工作区中“打开”,即把该表“装入”计算机内存,同时将其定义成当前工作区的当前表。
若完成了对表的操作,就要把表“关闭”,即把该表从计算机内存中“卸掉”。
另外,当用户没有“关闭”当前工作区的当前表时,又“打开”一个“新”表,系统会自动将“原”表“关闭”,视“新”表为当前工作区的当前表。
表的打开:在当前工作区中打开表可使用Use命令。
命令格式:Use [ <表名>.dbf ] [ In <工作区号>/<别名>] [Again][Alias <别名>] [Exclusive] / [Noupdate Shared]命令功能:打开以<表名>为名的表。
其中:(1)In <工作区号>/<别名>:指定打开表的工作区号(2)Again:可以在某一工作区中打开已在其他工作区中打开的表;(3)Alias <别名>:打开表的同时定义表的别名;(4)Exclusive :以独占方式打开表;(5)Noupdate Shared:以只读方式打开表。
表的关闭在当前工作区关闭表可使用以下命令。
(1)Close All命令命令格式:Close All命令功能:关闭所有打开的表,同时释放所有内存变量。
(2)Close Tables命令命令格式:Close Tables命令功能:关闭当前数据库中所有打开的表。
(3)Close Tables All命令命令格式:Close Tables All命令功能:关闭所有数据库中所有打开的表及自由表。
7.1.5 修改表结构修改表结构要在“表设计器”中进行,可以通过菜单操作进入“表设计器”窗口,也可以通过Modify Structure命令进入“表设计器”窗口。
命令格式:Modify Structure命令功能:修改当前数据库中当前表的结构。
7.2表中数据输入7.2.1 以追加方式输入数据向表输入数据通常有以下几种方法:(1)在表结构定义完成后,打开已有的表,选择“追加模式”命令,再在表“浏览”或表“编辑”窗口向表输入数据。
(2)在表结构已定义完成后,若表在某一个项目中,则要选打开“项目管理器”窗口,选择“数据”选项卡,单击“数据”左边的“+”,在展开的选项中,选择“表”选项,按“浏览”按钮,选择“追加模式”,进入表“浏览”或表“编辑”窗口向表输入数据。
(3)使用Append命令。
命令格式:Append [Blank]命令功能:以编辑方式向表中追加一个或多个记录,若选择了Blank选项,则直接追加一个空白记录。
7.2.2 备注型数据的输入因为备注型字段的长度不定,所以,备注型字段数据不能同其他类型的字段一样,直接在表“编辑”或表“浏览”窗口输入。
操作步骤如下:(1)打开表。
(2)进入表“编辑”或表“浏览”窗口。
(3)在“编辑”或“浏览”窗口,把光标移到备注型字段下双击,即可进入备注字段“编辑”窗口。
(4)在备注字段“编辑”窗口,可以输入或修改备注型数据。
(5)当数据输入或修改完成后,按按钮,关闭备注型字段“编辑”窗口并存盘。
如果不想保存输入或修改的内容,则要按ESC键退出备注型字段“编辑”窗口。
7.2.3 通用型数据的输入通用型字段数据多数用于存储OLE对象,如图像、声音、电子表格和字处理文档等,因为其长度的不确定性,通用型字段数据也不能直接在表“编辑”或表“浏览”窗口输入。
操作步骤如下:(1)打开表。
(2)进入表“编辑”或表“浏览”窗口。
(3)在“编辑”或“浏览”窗口,把光标移到通用型字段下双击,即可进入通用型字段“编辑”窗口。
(4)在Visual FoxPro系统主菜单下,打开“编辑”菜单,选择“插入对象”命令,进入“插入对象”窗口。
(5)在“插入对象”窗口,选择“由文件创建”选项,按“浏览”按钮,进入“浏览”窗口。
(6)在“浏览”窗口,选定要插入的文件,返回“插入对象”窗口。
(7)在“插入对象”窗口,按“确定”按钮,返回通用型字段“编辑”窗口。
(8)在通用型字段“编辑”窗口,按按钮,关闭通用型字段“编辑”窗口并存盘。
7.3 表中数据的显示与修改7.3.1 用编辑方式显示和修改数据在表“编辑”窗口,可以采用“编辑”方式显示和修改表中的数据;可以使用鼠标调整“编辑”窗口的大小、调整每个字段的显示顺序;还可以把“编辑”窗口改变成有“浏览”和“编辑”两种显示方式的窗口。
7.3.2 用浏览方式显示和修改数据在表“浏览”窗口,可以采用“浏览”方式显示和修改表中的数据;并可以使用鼠标调整“浏览”窗口的大小、调整每个字段的显示顺序和显示宽度;还可以把“浏览”窗口改变成有“浏览”和“编辑”两种方式显示的窗口。
7.3.3 使用操作命令浏览、修改数据1.Browse命令命令格式:Browse [Fields <字段名表>] [For <条件表达式>] [Last]命令功能:在表“浏览”窗口显示或修改当前表。
2.List命令命令格式:List / Display [<范围>] [Fields <字段名表>][For <条件表达式>] [Off] [To Printer] [To File <文件名>]命令功能:在显示器上按系统格式显示当前表中的数据。
7.3.4 控制字段和记录的访问1.限制对字段的访问限制字段的访问方法是:打开表,在“工作区属性”窗口,利用“字段选择器”筛选出有用的字段。
另外,可在对记录操作的命令中,使用“Fields <字段名表>”短语限制访问的字段。
2.限制对记录的访问限制记录的访问方法是:在“工作区属性”窗口,选择“数据过滤器”文本框,输入记录的筛选条件;或按文本框后面的按钮,进入“表达式生成器”窗口,在“表达式生成器”窗口,输入记录的筛选条件,再确认限制访问的记录即可结束操作。
7.4 数据库的创建与使用7.4.1 创建数据库创建数据库有以下几种操作方法。
(1)打开“文件”菜单,选择“新建”命令;然后选择“数据库”选项,按“新建”按钮,进入“数据库设计器”窗口;再打开“数据库”菜单,对数据库进行各种操作。
(2)在“项目管理器”窗口,选择“数据”选项卡,单击“数据”左边的“+”,在展开的选项中,选择“数据库”选项,按“新建”按钮,进入“数据库设计器”窗口。
(3)使用Create命令。
命令格式:Create DataBase <数据库名>命令功能:创建一个以<数据库名>为名的数据库。
7.4.2 打开数据库打开数据库有以下几种方法。
(1)打开“文件”菜单,选择“打开”命令;在“打开”窗口,在文件类型下拉框内,选择数据库类型,输入要打开的数据库名,按“确定”按钮;再在“数据库设计器”窗口,打开“数据库”菜单,对数据库进行各种操作。
(2)在“项目管理器”窗口,选择“数据”选项卡,单击“数据”左边的“+”,在展开的选项中,选择“数据库”选项,按“打开”按钮,进入“数据库设计器”窗口。
(3)使用Open命令或Modify命令。
命令格式:Open DataBase <数据库名> [Shared] [Exclusive]Modify DataBase <数据库名>命令功能:打开以<数据库名>为名的数据库。
打开以<数据库名>为名的数据库,并打开数据库设计器。
7.4.3 向数据库添加表(1)打开“数据库设计器”窗口,打开“数据库”菜单,选择“添加表”命令。
(2)在“项目管理器”窗口,选择“数据”选项卡,单击“数据”左边的“+”,在展开的选项中,选择“数据库”选项,按“添加”按钮。
(3)使用Add命令。
命令格式:Add Table <表名>命令功能:向已打开的数据库中添加以<表名>为名的表。
7.5数据库表的使用设置表中字段的显示标题操作步骤如下:(1)打开“人才管理”数据库,进入“数据库设计器”窗口。
(2)在“数据库设计器”窗口,激活需要设置字段显示标题的“人才档案”表。
(3)在“数据库设计器”窗口,打开“数据库”菜单,选择“浏览”命令,进入表“浏览”窗口。
(4)在“数据库设计器”窗口,打开“数据库”菜单,选择“修改”命令,进入“表设计器”窗口。
(5)在“表设计器”窗口,选择“显示”框中的“标题”文本框,输入“编号”字段的显示标题“地区编码和登记顺序”,按“确定”按钮,进入另一个“表设计器”窗口。
(6)在“表设计器”窗口,按“是”按钮,一个字段的标题便定义完成了,并返回“数据库设计器”窗口。
(7)在“数据库设计器”窗口,打开“数据库”菜单,选择“浏览”命令,进入表“浏览”窗口,浏览表中内容。