《oracle实训总结参考.doc》由会员分享,可在线阅读,更多相关《oracle实训总结参考.doc(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、oracle实训总结oracle实训总结Oracle实训总结系别:班级:姓名:学号:日期:实训总结:由于感到oracle实训担子很重,而自己的学识、能力和阅历与其任职都有一定的距离,所以总不敢掉以轻心,总在学习,向书本学习、向周围的领导学习,向同事学习,这样下来感觉自己半年来还是有了一定的进步。颠末一个星期的oracle数据库实训,让我体会到了日常仄凡是很多讲堂上所还出有启受的内容,很让人支获颇丰,明白若何往应用,而停止的一次剖析设计综开的练习。而本次数据库时真训的目标是让我们把握数据库系统的道理、手艺。将理论与现真联开,利用现有的数据库办理系统硬件、范例、科学地完成一个设计与真现。这个星期是
2、我们oracle数据库管理课的实训,经过一个星期的实训,让我领会到了许多平时课堂上所没有接受的课外知识,很让人受益匪浅,懂得如何去运用,而进行的一次分析设计综合的训练。而本次实训的目的是让我们掌握数据库系统的原理、技术。将理论与实际相结合,应用现有的数据库管理系统软件,规范、科学地完成一个设计与实现。这次我们实训的内容是从数据库、数据表的创建和修改开始的,表是建立关系数据库的基本结构,用来存储数据具有已定义的属性,在表的操作过程中,有查看表信息、查看表属性、修改表中的数据、删除表中的数据及修改表和删除表的操作。从实训中让我更明白一些知识,表是数据最重要的一个数据对象,表的创建好坏直接关系到数数
3、据库的成败,表的内容是越具体越好,但是也不能太繁琐,以后在实际应用中多使用表,对表的规划和理解就会越深刻。我们实训的另一个内容是数据库的约束、视图、查询。从中我们了解到查询语句的基本结构,和简单SELECT语句的使用,多表连接查询。而在视图的操作中,也了解到了视图是常见的数据库对象,是提供查看和存取数据的另一种途径,对查询执行的大部分操作,使用视图一样可以完成。使用视图不仅可以简化数据操作,还可以提高数据库的安全性,不仅可以检索数据,也可以通过视图向基表中添加、修改和删除数据。存储过程、触发器也是我们实训的内容之一,在操作中有建立存储过程,执行存储过程,及查看和修改存储过程,这些都是非常基础的
4、东西,但对用户却是非常重要的呢,只有熟悉了T_SQL语言,才能更好的掌握更多的东西。我们还学习了,数据库的管理、数据的导入、导出、备份和还原。有oracle安全访问控制;登录账户的管理;数据库角色的管理;用户权限管理。维护数据库的安全是确保数据库正常运行的重要工作。数据的备份是对oracle数据事务日志进行拷贝,数据库备份记录了在进行备份操作的数据库中所有数据的状态。而数据的备份还分为数据库完整备份、差异备份、事务日志备份、文件及文件组备份。做数据备份就是为了以后的数据库恢复用。在实训内容上我们还做了图书管理数据库,其中的要求包含了许多数据库的对象,综合了我们所学的许多知识,让我们更努力的把所
5、学到的东西运用上去。实训课是在学习与探索中度过的,短暂的一星期实训是结束了,但其中让我们学到了许多知识,出现许多未知的为什么,如仓库管理数据库的初步设置、数据备份与还原的步骤,如何建立视图、触发器等一系列的问题,正是在老师和同学的共同努力之下,我们才一步步把问题解决了,最终完成了不可能完成的任务。日期:2022年12月25日扩展阅读:ORACLE实训总结1、Conn/assysdba:以sysdba连接数据库,在这里可以解锁system、hr(oracle内建的用户名)、scott(oracle内建的用户名)用户,并修改它们的密码。2、修改密码:Alteruseridentifiedby3、解
6、锁用户:Alteruseraccountunlock4、解锁hr、scott,并修改system、hr、scott密码Alteruserhraccountunlock;Alteruserscottaccountunlock;Alteruserhridentifiedbyk;Alteruserscottidentifiedbyk;Alterusersystemidentifiedbyk;5、连接网络数据库在product10.0.2db_1NETWORKADMINtnsname.ora文件中添加内容:test=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=)
7、(PORT=1521)(CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=orcl)连接数据库时,输入:conn/test6、创建用户的语句以创建用户名hr为例:Connsystem/assysdba;/连接到指定数据库Dropuserhrcascade;/如果hr用户名已存在的话删除该用户名Createuserhridentifiedbyhrdefaulttablespaceuserstemporarytablespacetemp;/创建用户hrHostimphr/hrfile=hr.dmplog=1.logfromuser=hrtouser=hrig
8、nore=y;7、hr环境搭建connhr/k:以用户名hr、密码k连接数据库createtableEMP(EMPNONUMBER(6)notnull,ENAMEVARCHAR2(25),HIREDATEDATE,JOBVARCHAR2(10),SALNUMBER(8,2),COMMNUMBER(2,2),DEPTNONUMBER(4);INSERTINTOEMPSELECTEMPLOYEE_ID,LAST_NAME,HIRE_DATE,JOB_ID,SALARY,COMMISSION_PCT,DEPARTMENT_IDFROMEMPLOYEES;createtableDEPT(DEPTNON
9、UMBER(4)notnull,DNAMEVARCHAR2(30),LOCNUMBER(4);INSERTINTODEPTSELECTDEPARTMENT_ID,DEPARTMENT_NAME,LOCATION_IDFROMDEPARTMENTS;createtableemp_jobasselectempno,jobfromempwhere1=2;insertintoemp_job(empno,job)selectempno,jobfromempwheredeptno=30;createtablenew_emp(id,name)asselectempno,enamefromemp;create
10、tableSALGRADES(grade_levelvarchar2(4),lowest_salaryNUMBER,highest_salaryNUMBER);insertintosalgradesvalues(L1,1000,2999);insertintosalgradesvalues(L2,3000,5999);insertintosalgradesvalues(L3,6000,8999);insertintosalgradesvalues(L4,9000,14999);insertintosalgradesvalues(L5,15000,22999);insertintosalgrad
11、esvalues(L6,23000,30000);commit;8、SQL语句的分类DQL:dataquerylanguage数据查询语言:selectDML:datamanipulationlanguage数据操作语言insert/update/delete/mergeDDL:datedefinitionlanguage数据定义语言create/alter/drop/truncateDCL:datecontrollanguage数据控制语言grant/revokeTCL:transitoncontrollanguage事务控制语言commit/rollback/savepoint9、NULL
12、:它不等于零或空格,任意的类型都可以支持nulla)包含null的任何算术表达式的结果都为nullb)包含null的连接表达式等于与”(空字符串)连接10、列别明的两种书写形式a)列名列别名b)列名as列别名11、列别名必须加”的情况a)列别名中包含有空格b)列别名中要求区分大小写c)列别名中包含有特殊字符12、使用|连接符代替,实例:Selectfirst_name|last_name|sphonenumberis|phone_number“employeePhonenumber”fromemployees;其中first_name、last_name、phone_number位列变量,表示
13、输出空格,中前两个表示输出,sphonenumberis表示输出sphonenumber,”employeePhonenumber”表示输出列的别名。13、SQL*PLUS/ISQL*PLUS命令a)desc:显示表结构,其中desc是describe的缩写,可以写全。b)set系统变量on|off,例如:setheadingon|off:控制是否显示列标题。setescapeon|off:控制是否打开转义符,showescape:显示转义字符setautocommiton|off:空值是否打开自动提交,showautocommit:显示当前提交方式14、ISQL*PLUS的默认显示格式Dat
14、e和Character型左对齐,Numeric型右对齐、列标题居中大写字符函数:其中字符串可以代表列名或字符表达式a)lower(字符串)将所有大写字符转换为小写字符b)upper(字符串)将所有小写字符转换为大写字符c)iniicap(字符串)所有单词的首字母大写,其它的小写d)concat(字符串1,字符串2)将字符串1与字符串2连接e)substr(字符串,m,n)从字符串中第m位开始截取n位,字符串从1开始计数f)length(字符串)返回字符串的长度g)instr(字符串1,字符串2,m,n)返回字符串2在字符串1中,从第m位开始,第n次出现的位置。h)lpad(字符串1,n,字符串
15、2)用字符串2在字符串1的左边进行填充,使字符串1达到n位i)rpad(字符串1,n,字符串2)用字符串2在字符串1的右边进行填充,使字符串1达到n位j)trim(leading|trailing|both字符from字符串)将字符串中开头(leading)和结尾(trailing)的指定字符(只能是字符)去掉。k)replace(字符串1,字符串2,字符串3)将字符串1中的字符串2用字符串3替换。数字函数a)round(数字,n)将数字四舍五入到小数点后n位,n为负数表示小数点前|n|位。b)trunc(数字,n)将数字截取到小数点后n位,其他同上。c)mod(m,n)取m除以n的余数日期函
16、数a)sysdate返回当前系统日期,不能写成sysdate()b)months_between(date1,date2)返回date1与date2之间的月数c)add_months(date,n)在date的基础上增加n个月d)next_day(date,d)返回date之后的第一个指定d,例如:next_day(16-8月-11,星期一),返回11年8月16日之后的第一个星期一是:22-8月-11e)last_day(date)返回date所在月的最后一天,例如:last_day(16-8月-11)返回:31-8月-11f)round(date,fmt)将date按fmt格式四舍五入,fm
17、t可选默认为DDg)trunc(date,fmt)将date按fmt格式四舍五入,fmt可选默认为DD,时间提前h)extract(XXfromdate)从date中提取出XX(month、day、year)数据类型之间的转换a)to_char(date|number,fmt)将date或number转换为指定格式fmt的字符串,fmt可省略b)to_number(char,fmt)将char转换为指定格式fmt数字,fmt可省略c)to_date(char,fmt)将char转换为指定格式fmtdate,fmt可省略常用的日期格式a)yyyy:四位数字的年份b)yy:两位数字的年份c)yea
18、r:年份的英文拼写d)mm:两位数字的月份e)month:月份的英文拼写f)dy:星期英文的前三位g)day:星期英文的全拼h)d:星期的第几天,星期日为第一天i)dd:一个月中的第几天j)ddd:一年中的第几天k)am或pm:上下午l)hh或hh12或hh24:表示小时12小时制24小时制m)mi:表示分钟n)ss:表示秒数字格式a)9:一位数字b)0:一位数字或前导零c)$:美元符号d)L:按照地区显示货币符号e).:小数点f),千位分隔符其它函数a)nvl(表达式1,表达式2):如果表达式1的值不为null,返回表达式1的值,否则返回表达式2的值,数据格式可以是日期、字符、数字,但表达式
19、1和表达式2的数据类型必须一致。b)nvl2(表达式1,表达式2,表达式3):如果表达式1的值不为空,返回表达式2的值,否则返回表达式3的值。表达式2和表达式3的数据类型必须相同。c)nullif(表达式1,表达式2):如果两个参数不相等,返回表达式1的值;相等,则返回空值。d)coalesce(x1,x2xn):返回第一个非空的参数。e)(case表达式1when条件1then结果1when条件2then结果2else结果nend):如果表达式为条件1匹配就返回结果1最后默认返回else后的结果n。f)Decode(表达式,条件1,结果1,条件2,结果2缺省值):如果表达式与条件1匹配则返回
20、结果1,缺省返回缺省值。表别名如果定义了表别名,那么之后只能使用表别名而不能使用原表名。连接语法Selectfromtable1crossjointable2|naturaljointable2|jointable2using(column_name)|jointable2on(table1.column_name=table2.column_name)|left|right|fullouterjointable2on(table1.column_name=table2.column_name)a)crossjointable2:生成笛卡尔积b)nutualjointable2:自然连接c)j
21、ointable2using(column_name):使用指定列连接,两列同名d)jointable2on(table1.column_name=table2.column_name):使用指定列连接,两列可以不同名e)left|right|fullouterjointable2on(table1.column_name=table2.column_name):外连接union和unionalla)union和unionall连接的两个结果集所包含的字段要相等。b)union的结果去掉重复的记录,unionall不去掉重复的记录。Groupby的特点a)在groupby子句的列可以不在sel
22、ect语句中出现,但在select字句中出现的非分组列必须在groupby字句中出现b)Groupby后面可以有多列Select语句的执行过程:顺序为from-where-groupby-having-select-orderbya)from:从from子句中找到需要查询的表b)where:进行非分组函数的筛选判断c)groupby:完成分组操作d)having:完成分组函数的筛选判断e)select:选择要显示的列或表达式或组函数f)orderby:对得到的结果集进行排序组函数的嵌套:最多为两级,例如:Selectmax(count(employee_id)fromemployeesgrou
23、pbydepartment_id;子查询特点:a)子查询只能在括号中b)子查询需要写在运算符右边c)子查询可以写在where、having、from中。分类:a)单行子查询:用=、=、=等连接,子查询返回结果只有一条b)多行子查询:用any、all、in等连接,子查询的返回结果只有一条c)多列子查询:子查询的返回结果中含有多列。例如:selecte.last_namee.salary,e.job_id,j.avgsalfromemployeese,(selectjob_id,avg(salary)avgsalfromemployeesgroupbyjob_id)jwheree.job_id=j
24、.job_idande.salaryj.avgsal子查询中的空值问题示例:selecta.last_name,a.salaryfromemployeesawherea.employee_idnotin(selectb.manager_idfromemployeesb)的返回结果为空原因:在employees表中有manager_id为null的记录,而null&true=trueExists和notexistsa)子查询中如果找到符合条件的记录,子查询语句不会继续执行,返回trueb)子查询中如果到表的末尾也没有找到符合条件的记录,返回falseInsert插入空值插入空值时,可以写null
25、或使用默认值修改示例:updatedossiersetcountry_code=defaultwhereid=2创建表的语法Createtabletable_name(column,column)asselect:对于select中的表达式(比如:salary*12)必须给定列别名,否则报错。引用另一个用户的表用户名.表名Oracle中表的分类a)用户表:有用户创建和维护的表的集合,它包括用户所使用的数据b)数据字典:由Oracle服务器创建和维护的表的集合,它包括数据库信息,比如表的定义、数据库结构信息等。Oracle数据库的伪列和伪表伪表:dual用于查询不涉及具体表时伪列:rowin由系统自动产生,表示行地址添加、修改、删除列a)添加:altertabletable_nameadd(columnname,datatypenotnulldefault)b)修改:altertabletable_namemodify(columnname,datatypenotnulldefault)c)删除:altertabletable_namedrop(columnname1,columnname2)重命名表名语法:renameoldnametonewname第 11 页 共 11 页
限制150内