第一篇:SQL基础数据库语法
一、表空间操作
1.创建表空间
Create tablespace xxx(表名)Datafile ’x:xxxxxx.dbf(文件地址)’ Size 10m(文件大小)autoexdend on;2.删除表空间
Droptablespacexxx(表空间名); 删除表空间及文件
Drop tablespace xxx including contents and datafiles;
二、用户操作
1.创建用户
Create user xxx(用户名)identified by xxx(密码)Default tablespace xxx(表名);2.删除用户
Drop user xxx(用户名)cascade;3.授予权限
Grantconnect,resource(权限)to xxx(用户名);Grant dba(最高权限)to xxx(用户名);Grant select on scott.emp to xxx(用户名);Grant update on scott.emp to xxx(用户名);撤销权限
Revoke connect,resource(权限)fromxxx(用户名);4.用户登录
Connxxx(用户名)/xxx(密码)@xxx(表空间名);
三、表数据操作
1.创建表结构语法
1)创建表结构
CREATE TABLE student(stu_no CHAR(4)PRIMARY KEY NOT NULL,--学号,主键,非空
stu_name VARCHAR2(30)NOT NULL,--姓名,非空
stu_id VARCHAR2(18),--身份证号,代表18位整数
stu_gid Number(10),--年级
stu_age NUMBER(3,0)--年龄);2)复制表结构
利用现有表创建新表,select 后边有多少字段,新表将有多少个字段,主键不会被创建
CREATE TABLE stu_info AS SELECT stu_no,stu_age FROM student;3)修改表结构
修改student表,添加stu_seat(座号)和stu_Address(住址)两个列
ALTER TABLE student ADD(stu_seat NUMERIC(2,0),stu_address VARCHAR2(20));修改student表的列的定义 ALTER TABLE student modify(stu_name VARCHAR2(50), stu_address VARCHAR2(100));删除student表中stu_ address和stu_seat列 ALTER TABLE student drop(stu_address, stu_seat);修改student表列名
Alter table student rename column stu_no TO rempno;
4)删除表结构
删除student表结构及数据 这种删除的情况,可以恢复; Drop table student;只删除表数据,每条删除的记录不写日志,省资源,效律比delete高
但是,绝对情况下都不使用truncate删除表,因为不可以恢复。Truncate table student;5)添加注释
Comment on table student is '学生表';Comment on column student.name is '名称';2.插入表数据
往student表插入数据 Insert into
student(stu_no,stu_name,stu_id,stu_gid,stu_age)values('a001','张大','44***92111',10,19);insert into student(stu_no,stu_name,stu_id,stu_gid,stu_age)values('a002','张二','44***92112',10,20);insert into
student(stu_no,stu_name,stu_id,stu_gid,stu_age)values('a003','张三','44***92113',10,20);commit;最后的commit提交数据到数据库,否则只是在缓存插入了表数据。
3.删除表数据
根据条件删除表数据
Delete from student where stu_no='a004';请空表,不写日志,省资源,效律高,属于数据定义语言 Truncate table student;4.修改表数据
修改学号为‘a002’学员的名字为‘李二’
Update student set(列)stu_name='李二' where stu_no='a002';所有学员的年龄都加1 Update student set(列)stu_age=stu_age+1;5.查询表数据
order bygroup bywherehavinglikein 等子查询方法 1)distinct去重复查询
查询(结果)无重复数据行,distinct关键字使用:
查询结果包括学员名字和年龄,如果存在学员名字和年龄都一样的多条记录将只返回一条
-->Select distinctstu_name,stu_age from student;2)Order by结果排序
Order by 语法默认是升序,加desc语法表示降序。E:工的姓名按首字母排序,并写出姓名的长度(length)。select last_name,length(last_name)from employees order by last_name;降序:
Select last_name,length(last_name)from employees order by last_name desc;
第二篇:SQL数据库心得
黄淮学院 2015---2016学年第 一 学期 《C#数据库应用程序开发技术与案例教程》课程
题目:
学习报告
院
系:数学科学系 专
业:数学与应用数学 年
级:1301B 姓
名:曹占营 学
号:1331110101 任课教师:杨锋英
2015年 12 月 30日
C#数据库学习报告
在日常生活中,我们和朋友、亲戚联系,会广泛用到通讯录,因此这门课程以通讯录开发为案例,教我们学习软件开发。
软件开发是一项非常注重实践工作,不可能只凭看书、看视频就学会软件开发,必须扎扎实实、一行一行的编写代码,不断积累项目经验,才能真正掌握编程技术,所以我们要亲自上级编写程序,才能真正掌握软件开发技术。
本书分为基础篇、进阶篇、高级篇,由浅入深地介绍了基于C#的数据库编程技术,所用的开发工具为Visual Studio 2008、SQL Server 2005以及Access 2007。
学习数据库的内容是从数据库、数据表的创建和修改开始的,表是建立关系数据库的基本结构,用来存储数据具有已定义的属性,在表的操作过程中,有查看表信息、查看表属性、修改表中的数据、删除表中的数据及修改表和删除表的操作。从课程中让我更明白一些知识,查询可以通过SQL语言进行完成,这样加深了查询语句的基本结构,让我们能更好的掌握其中语句,方便于我们后面的学习和应用。表是数据最重要的一个数据对象,表的创建好坏直接关系到数数据库的成败,表的内容是越具体越好,但是也不能太繁琐,以后在实际应用中多使用表,对表的规划和理解就会越深刻。在编程方面是需要我们对于编程有逻辑思维能力及一定的编程技巧。在数据库中插入表、表中的信息等都需要注意,不然很容易出错。
在基础篇中,详细讲解了通讯录系统的设计、开发和安装部署这样一个完整过程,对各个任务进行详细讲解。基础篇学习分为9个任务,分别为系统分析与设计、用户登录、主窗体设计、联系人分组管理、联系人管理、用户密码修改、数据库备份与恢复、设计“关于”窗体、系统安装与部署。学完基础篇,即可开发出一个功能较为完备的通讯录系统。在联系人管理任务学习中,由于在Contact表中保存的是分组编号,而窗体上要显示的是分组名称,所以在查询语句中需要级联查询,即SQL语句为”select Contact.Id, Name, Phone, Email, QQ, GroupName from Contact, ContactGroup where Contact.GroupId = ContactGroup.Id”。为了实现代码复用,可以提供查询功能,根据用户选择的擦寻天剑,拼接产生SQL语句。同时为了支持模糊查询,还在SQL语句中用了like语句。通过SqlDataAdapter的Fill方法填充数据集,获取数据。数据集中有了数据以后,我们只需设置DataGridView控件的DataSource属性,就可以显示数据了。
在进阶篇中,介绍了企业项目开发中广发用到的参数化SQL语句、存储过程使用及定义数据库操作类,分为3个任务学习,分别为使用参数化SQL语句、使用存储过程、使用自定义数据库操作类,进一步提高我们的数据库编程能力。在使用存储过程任务学习中,了解到存储过程是在大型数据库系统中,一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。在性能方面,存储过程有如下的优点。(1)与编译,存储过程预先编译好放在数据库内,减少编译语句所花的时间。(2)缓存,编译好的存储过程会进入缓存,所以对于经常执行的存储过程,除了第一次执行外,其他次执行的书都会有明显提高。(3)减少网络传输,特别对于处理一些数据的存储过程,不必像直接用SQL语句实现那样多次传送数据到客户端。通过前面的学习,细细体会对数据库的操作,可以发现,这么多操作其实可以分为4种。(1)对数据库进行非连接式查询操作,返回多条记录。这种操作可以通过SqlDataAdapter对象的Fill方法来完成,即把查询得到的结果填充到DataTable(或DataSet)对象中。(2)对数据库进行连接式查询操作,返回多条查询记录。这种操作可以通过SqlCommand对象的ExecuteReader方法来完成,返回SqlDataReader对象。(3)从数据库中检索单值。这种操作可以通过SqlCommand对象的ExecuteNonQuery方法来完成。ExecuteScalar方法返回的是Object类型,需要根据实际情况进行类型转换。(4)对数据库执行增、删、改操作。这种操作可以通过SqlCommand对象的ExecuteNonQuery方法来完成,返回增、删、改操作后数据库中受影响的行数。
在高级篇中,分为4个任务学习,分别为开发基于三层构架的通讯录程序、开发基于Access的通讯录程序、实现基于抽象工厂模式的三层架构、使用MD5加密用户密码。首先详细讲解了基于三层构架的通讯录程序开发过程以及如何开发一个基于Access的通讯录系统。最后,介绍了如何采用MD5加密技术对用户密码加密。MD5加密技术也是实际项目开发中广泛用到的,通过MD5加密用户密码,可以提高程序的安全性。“三层架构”一词中的“三层”是指:“表示层”、“业务逻辑层”、“数据访问层”。表示层:位于最外层,离用户最近。用于显示和接收用户输入的数据,为用户提供一种交互式操作界面。表示层的常见形式为WinFrom和WebForm。业务逻辑层:负责处理用户输入的信息,或者是将这些信息发送给数据访问层进行保存,或者是调用数据访问层中的函数再次读出这些数据。业务逻辑层也可以包括一些对“商业逻辑”描述代码在里面。数据访问层:仅实现对数据的保存和读取操作。可以访问数据库系统、二进制文件、文本文档或是XML文档。
在这一学期有限的几次实验课后,我虽然没有学会很多,但也学会了一些简单的操作,我学会了一些简单的数据运算,会建立一些简单的表。有时候在做实验时,对于实验中的一些东西我不怎么了解,但我还会去做,因为我想只有多练习才能熟练,也才能理解掌握知识。我不知道这一门课对其他同学来说怎么样,但对我来说却有些难,但我会努力。因为我认为它对我以后考计算机二级有很大的帮助。
很快这一学期马上就要结束了,数据库这一门课也很快就要结束了,但这一学期的学习让我知道了很多,也告诉了我在以后的人生中如何去做事,如何去做人。尤其是老师的耐心,老师的敬业精神感动了我,再做任何事时都应该认真负责,任何一个人都应该被尊重。
第三篇:SQL数据库选择题及答案
1、在数据库技术中,独立于计算机系统的模型是_C__。A、面向对象的模型B、关系模型C、E-R模型D、层次模型
2、数据库系统的控制中枢是__B_。A、数据库、b、数据库管理系统C、数据库管理员D、数据库应用系统
3、使用SQL命令将学生表STUDENT中的学生年龄AGE字段的值增加1岁,应该使用的命令是__C_。
A、UPDATE SET AGE WITH AGE+1
B、REPLACE AGE WITH AGE+1
C、UPDATE STUDENT SET AGE=AGE+1
D、UPDATE STUDENT AGE WITH AGE+1
4、在关系数据库中,建立数据库表时,将年龄字段值限制在12~40岁之间的这种约束属于__B__。
A、视图完整性约束B、域完整性约束C、参照完整性约束D、实体完整性约束
5、在 SQL 语句中,与 X BETWEEN 20 AND 30 等价的表达式是__D_。A、X>=20 AND X<30
B、X>20 AND X<30
C、X>20 AND X<=30
D、X>=20 AND X<=30
6、在数据库中,概念模型是_D__。A、用于现实的建模,与具体的DBMS有关B、用于信息世界的建模,与具体的DBMS有关
C、用于现实的建模,与具体的DBMS无关D、用于信息世界的建模,与具体的DBMS无关
7、数据库的并发操作可能带来的问题包括__B_。A非法用户的使用B丢失更新C数据独立性会提高D增加数据冗余度
8、在关系数据库中,模式对应的是__A___。A、视图和所有基本表
B、视图和部分基本表
C、基本表
D、索引
9、能实现绝对的与平台无关性的Web数据库访问技术是_D_。A、ADO
B、ActiveX
C、WebbaseAPI
D、JDBC
10、在下列描述中,正确的描述是__B___。
A、SQL 是一种过程化语言B、SQL 采用集合操作方式
C、SQL 不能嵌入到高级语言程序中
D、SQL 是一种 DBMS
11、数据库系统是由__A__组成的。A、数据库、数据库管理系统和用户
B、数据文件、命令文件和报表
C、数据库文件结构和数据
D、常量、变量和函数
12、在SQL查询时,使用WHERE子句指出的是__B__。A、查询目标B、查询条件C、查询视图D、查询结果
13、在下列 RDMBS 产品中,属于小型数据库系统的是_A_。A、Access B、Oracle C、Sybase D、Informix
14、数据库类型是按照_A_来划分的。
A、数据模型B、记录形式C、数据存取方法D、文件形式
15、作为Microsoft Office家族成员之一的_A_数据库,能够与其他Office组件进行数据交换共享数据资源,易于生成集文字处理、图表生成和数据管理于一体的办公自动化系统。A、Access
B、Oracle
C、Sybase
D、Informix
16、数据库管理系统更适合于_D_方面的应用。A、CAD
B、过程控制C、科学计算D、数据处理
17、下列四组SQL命令,全部属于数据定义语句的命令是_C__。A、CREATE,DROP,ALTER
B、CREATE,DROP,UPDATE
C、CREATE,DROP,GRANT
D、CREATE,DROP,SELECT
18、通过Internet及浏览器处理的数据库,应该是_C__处理。A、集中式
B、分布式
C、主从结构式D、以上3种模式
19、数据的逻辑独立性是指__D_。A、数据与存储结构的逻辑独立性 B、数据元素之间的逻辑独立性
C、存储结构与物理结构的逻辑独立性
D、数据与程序的逻辑独立性
20、在数据库技术中,独立于计算机系统的模型是_C__。A面向对象的模型
B关系模型
C、E-R模型
D、层次模型
21、关系代数的3个基本运算是–D--、投影、连接。A、关系与B、蕴含C、关系或D、选择
22、下面命题不正确的是:A、若冗余数据可以控制,则数据更新的一致性得以保证
B、数据库减少了不必要的数据冗余C、数据库的数据可以共享D、数据库中不存在数据冗余
23、在基本SQL中不可以实现: A、定义视图B、并发控制C、定义基表D、查询视图和基表
24、用二维表来表示实体及实体之间联系的数据模型称为_C___。
A、实体-联系模型B、层次模型C、关系模型D、网状模型
25、查找工资在600元以上并且职称为工程师的纪录,逻辑表达式为_D___。
A、“工资”>600.OR.职称=“工程师”
B、工资>600.AND.职称=工程师
C、“工资”>600.AND.“职称”=“工程师”
D、工资>600.AND.职称=“工程师”
26、数据库镜像可以用于__C_。(1分)
A、实现数据库的安全性
B、实现数据共享C、进行数据库恢复或并发操作D、保证数据库的完整性
27、在下列类型的数据库系统中,应用最广泛的是__C___。(1分)
A、分布型数据库系统B、逻辑型数据库系统C、关系型数据库系统D、层次型数据库系统
28、在下列描述中,正确的描述是__B__。(1分)A、SQL 是一种过程化语言B、SQL 采用集合操作方式
C、SQL 不能嵌入到高级语言程序中
D、SQL 是一种 DBMS
第四篇:数据库sql语言总结
插入句型:
insertinto<表名> [各属性名]values(<常量1>,<常量2>……)
删除元组或者二维表:
delete from<表名>[ where <条件> ]
删除属性:
altertable<表名>dropcolumn<列名>
增加某表的属性:
altertable<表名>add<列名> 类型
修改句型:
update<表名>set<列名> =<表达式>[where<条件>]
修改某表当中的属性类型:
altertable<表名>altercolumn<列名><转换的类型>;
显示表的一些基本情况
EXEC sp_help'<表名>'
更改当前数据库中用户创建对象(如表、列或用户定义数据类型)的名称 sp_rename ‘<旧的表名>’, ‘<新的表名>’
修改表的列名 sp_rename'<表名>.
小注:上面的语句最后不需要加分号
判断表中是否存在某列的语句
if exists(select * from syscolumns where id = object_id('stu')and name='Sno')
print 'stu exists'
else print 'stu not exists'
将表中的某列设置为主码:
alter table stu addSno char primary key;
判断表是否存在if exists(select count(*)from sysobjects where type='U' and name='stu')
查询某个表中字段的列名和数据类型
select column_name,data_type from information_schema.columns where table_name = '表名';
第五篇:SQL数据库学习心得
SQL数据库学习心得
一 数据库课程总结
(一)数据库概述数据
(1)数据库中存储的基本对象,是描述事物的符号记录(如存储某一个人
(2)数据的种类包括文字、图形、图象、声音
(3)数据的特点是数据与其语义是不可分的。数据库
(1)(database,简称DB)是指长期存储在电脑内有组织的、可共享的数据集合;
(2)数据库管理系统(DatabaseManagement System,简称DBMS),是位于用户与操作系统之间的一层数据管理软件。关系数据库基础
(1)元组(Tuple)表中的一行即为一个元组。
(2)属性(Attribute)表中的一列即为一个属性,给每一个属性起一个名称即属性
名。
(3)主码(Key)表中的某个属性组,它可以唯一确定一个元组。
(4)域(Domain)属性的取值范围。
(5)分量元组中的一个属性值。
(二)SQL Server概述SQL Server的版本
(1)企业版,作为生产使用
(2)个人版,供移动用户使用
(3)标准版,作为小工作组或部门使用
(4)开发板,供程序员开发测试使用SQL数据库的创建
(1)创建数据库的过程就是确定数据库名称、大小、存放位置等信息。
(2)数据库文件包括主数据库文件(.mdf)、次数据文件(.ndf)、事务日志文件(.ldf)
(3)3种方式创建数据库:使用数据库创建向导、使用企业管理器、使用SQL语句在查
询分析器中创建。
(三)数据库中的表创建表两种方式:使用企业管理器、使用SQL语句
2修改表,修改操作包括:增加字段、删除字段、修改字段(名称、修改其已有的属性)两种方式,使用企业管理器、使用SQL语句
(四)数据查询
1基本的SELECT语句,例查询Readers表中所有记录的信息SELECT*FROM Readers 2查询语句的统计功能
3数据的连接
外连接的结果集中,不仅包括满足连接条件记录,还包括不满足连接条件的记录。连接方式分为:左外连接、右外连接、全外连接。
(五)数据完整性
1定义:数据完整性是指存储在数据库中的数据的一致性和准确性。
2实体完整性
又称行完整性,要求表中不能存在完全相同的记录,而且每条记录都要具有一个非空且不重复的主键值。
3使用约束:约束是保证数据完整性的有效方法,(1)PRIMARY KEY(主键约束)特点:每个表只能定义一个主键、主键值不可为空、主键值不可重复。
(2)UNIQUE(唯一约束)确保表中的某非主键列不输入重复值,PRIMARY KEY 与 UNIQUE的区别、约束数量、是否允许NULL值
(3)CHECK(检查约束),用于限制输入到列中的值的范围
(六)数据库的安全
1对于SQL Server来说,提供身份验证和权限验证两种保护方式。
(1)身份验证模式: Windows验证模式,只限于本机使用; 混合验证模式,本机或远程均可访问角色管理是一种权限管理的方法,角色中的每一用户都拥有此角色中的所有权限。3数据库角色提供了在数据库级别上的管理权限组。
(七)备份与恢复
1备份数据库,使用SQL语句备份
步骤:(1)创建备份设备
(2)备份数据库(完全数据库备份、差异备份、日志备份、文件与文件组备份)2恢复数据库(使用企业管理器恢复、使用SQL语句恢复)
二 数据库课程心得
在学习数据库和数据表创建和修改时,了解到表是建立关系数据库的基本结构,用来存储数据具有已定义的属性,在表的操作过程中,有查看表信息、查看表属性、修改表中的数据、删除表中的数据及修改表和删除表的操作。从课程中中让我更明白一些知识,表是数据最重要的一个数据对象,表的创建好坏直接关系到数数据库的成败,表的内容是越具体越好,但是也不能太繁琐,以后在实际应用中多使用表,对表的规划和理解就会越深刻。我们上机的另一个内容是数据库的约束、视图、查询。从中我们了解到查询语句的基本结构,和简单SELECT语句的使用,多表连接查询。而在视图的操作中,也了解到了视图是常见的数据库对象,是提供查看和存取数据的另一种途径,对查询执行的大部分操作,使用视图一样可以完成。使用视图不仅可以简化数据操作,还可以提高数据库的安全性,不仅可以检索数据,也可以通过视图向基表中添加、修改和删除数据。存储过程、触发器也是我们学习的内容之一,在操作中有建立存储过程,执行存储过程,及查看和修改存储过程,这些都是非常基础的东西,但对用户却是非常重要的呢,只有熟悉了T_SQL语言,才能更好的掌握更多的东西。我们还学习了,SQL管理、数据的导入、导出、备份和还原。有SQL Server 安全访问控制;登录账户的管理;数据库角色的管理;用户权限管理。维护数据库的安全是确保数据库正常运行的重要工作。数据的备份是对SQL Server数据事务日志进行拷贝,数据库备份记录了在进行备份操作的数据库中所有数据的状态。而数据的备份还分为数据库完整备份、差异备份、事务日志备份、文件及文件组备份。做数据备份就是为了以后的数据库恢复用。我们还做了仓库管理数据库,其中的要求包含了许多数据库的对象,综合了我们所学的许多知识,让我们更努力的把所学到的东西运用上去。