MySQL数据库基础与实践 第2版 课后习题答案汇 夏辉 CH01 -10_第1页
MySQL数据库基础与实践 第2版 课后习题答案汇 夏辉 CH01 -10_第2页
MySQL数据库基础与实践 第2版 课后习题答案汇 夏辉 CH01 -10_第3页
MySQL数据库基础与实践 第2版 课后习题答案汇 夏辉 CH01 -10_第4页
MySQL数据库基础与实践 第2版 课后习题答案汇 夏辉 CH01 -10_第5页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

MySQL数据库基础与实践错误!文档中没有指定样式的文字。 PAGE16实践与练习答案第1章1.选择题1-5BBACA6-10ACCBB2.概念题数据库(DstabaseDB)是“按照某种数据结构对数据进行组织、存储和管理的容器”,简单的说就是用来存储、管理数据的容器。数据库系统(DstabaseSystem,DBS)是指在计算机中引入数据库后的系统,一般由数据库、数据库管理系统、应用程序、数据库管理员组成。数据库管理系统(DstabaseManagementSystem,DBMS)是一个管理、控制数据库容器中各种数据库对象的系统软件。使用关系模型对数据进行组织、存储和管理的数据库称为关系数据库,关系数据库系统是支持关系数据模型的数据库系统。表1-1SQL功能及包含的主要动词SQL功能动词数据定义CREATE、DROP、ALTER数据查询SELECT数据操纵INSERT、UPDATE、DELETE数据控制GRANT、REVOKE数据库设计分为如下6个阶段:需求分析阶段、概念结构设计阶段、逻辑结构设计阶段、数据库物理结构设计阶段、数据库实施阶段以及数据库运行于维护阶段。各阶段内容(略)。E-R图中的实体表示现实世界具有相同属性描述的事物的集合,不是某一个具体事物,而是一类事物的统称。E-R图中的实体通常使用矩形表示。E-R图中的属性通常表示实体的某种特征,也可以使用属性表示实体间关系的特征。一个实体通常包含多个属性,每个属性由属性名唯一标记,画在椭圆内。3.操作题(1)学生:学好、姓名、年龄、性别、班级名班级:班级名、班主任、班级人数(2)一个学生只能属于一个班级,一个班级可以有很多学生,多以班级和学生之间是1对多的关心,即1:n。(3)拥有(4)E-R图如下:第2章MySQL数据库概述 一、选择题DCDBBBBABC二、填空题1.UNIQUE2.PRIMARYKEY3.33064.ROOT5.SHOWDATABASES;三、操作题(1)createdatabaseschool;(2)useschool;createtablestudents(s_idchar(8)notnullprimarykey,s_namevarchar(10)notnull,s_sexchar(2), s_birthdatetime);(3)altertablestudentsadds_phonevarchar(20)notnull;(4)altertablestudentsdrops_birth;(5)droptablestudents;(6)dropdatabaseschool;第3章MySQL管理表记录实践与练习单选题:AABABBBADC概念题:MySQL中整数类型有几种?每种类型所占用的字节数为多少?MySQL中整数类型有:TINYINT、SMALLINT、MEDIUMINT、INT(INTEGER)和BIGINT。每种整数类型所占用字节数如表3-1所示。表3-1整数类型的字节数类型字节数TINYINT1字节SMALLINT2字节MEDIUMINT3字节INT(INTEGER)4字节BIGINT8字节MySQL中日期类型的种类及其取值范围是什么?日期时间类型包括:DATE、TIME、DATETIME、TIMESTAMP和YEAR。DATE表示日期,默认格式为YYYY-MM-DD;TIME表示时间,默认格式为HH:MM:SS;DATETIME和TIMESTAMP表示日期和时间,默认格式为YYYY-MM-DDHH:MM:SS;YEAR表示年份。日期时间类型及其表示范围如表3-3所示。表3-2日期时间类型及其取值范围类型最小值最大值DATE1000-01-019999-12-31TIME-838:59:59838:59:59DATETIME1000-01-0100:00:009999-12-3123:59:59TIMESTAMP1970-01-0108:00:012037年的某个时刻YEAR19012155MySQL中复合数据类型有几种?MySQL中的复合数据类型包括:ENUM枚举类型和SET集合类型。ENUM类型只允许从集合中取得某一个值,SET类型允许从集合中取得多个值。ENUM类型的数据最多可以包含65535个元素,SET类型的数据最多可以包含64个元素。使用什么命令可以查看MySQL服务器实例支持的字符集信息?使用MySQL命令“showcharacterset;”即可以查看当前MySQL服务实例支持的字符集、字符集的默认排序规则、字符集占用的最大字节长度等信息。使用什么命令可以查看MySQL服务器实例使用的字符集信息?使用MySQL命令“showvariableslike‘character%’;”可以查看当前服务实例使用的字符集信息。character_set_client:MySQL客户机的字符集,默认安装MySQL时,该值为latin1。character_set_connection:数据通信链路的字符集,当MySQL客户机向服务器发送请求时,请求数据以该字符集进行编码。默认安装MySQL时,该值为latin1。character_set_database:数据库字符集,默认安装MySQL时,该值为latin1。character_set_filesystem:MySQL服务器文件系统的字符集,该值固定为binary。character_set_results:结果集的字符集,MySQL服务器向MySQL客户机返回执行结果时,执行结果以该字符集进行编码。默认安装MySQL时,该值为latin1。character_set_server:MySQL服务实例字符集,默认安装MySQL时,该值为latin1。character_set_system:元数据(字段名、表名、数据库名等)的字符集,默认值为utf8。操作题:使用SQL语句完成以下操作:创建数据库及数据表,并在表中插入雇员信息。createdatabaseemployees_test;useemployees_test;createtableemployees(employee_idchar(4)primarykey,employee_namevarchar(20)notnull,employee_sexvarchar(4)notnull,departmentvarchar(20)notnull,salarydecimal(10,2)notnull);insertintoemployeesvalues('0001','刘卫平','男','开发部',5500.00);insertintoemployeesvalues('0002','马东','男','开发部',6200.00);insertintoemployeesvalues('0003','张明华','女','销售部',4500.00);insertintoemployeesvalues('0004','郭文斌','男','财务部',5000.00);insertintoemployeesvalues('0005','肖海燕','女','开发部',6000.00);修改“开发部”雇员的薪水,修改后其薪水增加20%。updateemployeessetsalary=salary+salary*0.2wheredepartment='开发部';将雇员表中性别为“男”的所有雇员信息复制到employee_copy表中。createtableemployee_copylikeemployees;insertintoemployee_copyselect*fromemployeeswhereemployee_sex='男';将employee_copy表中所有记录清空。truncateemployee_copy;第4章检索表记录 1.选择题BDBCAB2.填空题(1)SUM() (2)ORDERBYNameDESC(3)SELECT(4)WHERENameISNULL(5)-3.操作题(1)SELECT*FROMBookInfoWHEREB_NameLIKE'%MySQL%';(2)SELECT*FROMBookInfoWHEREB_Publisher='机械工业出版社'ANDB_Date>'2020-01-01';(3)SELECT*FROMBookInfoORDERBYB_MarketPriceDESC,B_Date;(4)SELECTU_ID,SUM(O_TotalPrice)订单总额FROMOrdersGROUPBYU_ID;(5)SELECTO_Time,SUM(O_TotalPrice)订单总额FROMOrdersGROUPBYO_TimeORDERBYSUM(O_TotalPrice)DESC;(6)SELECTBI.B_ID,BI.B_NameFROMBookInfoBIINNERJOINOrderDetailsODONBI.B_ID=OD.B_IDWHEREOD.O_IDIN(SELECTO.O_IDFROMOrdersOINNERJOINUsersUONO.U_ID=U.U_IDWHEREU.U_Name='lijuan');(7)UPDATEOrdersSETO_Status='1'WHERE'linli'=(SELECTU_NameFROMUsersWHEREUsers.U_ID=Orders.U_ID);实践与练习答案第5章1.选择题1-5DBCAA6-10DBAAA2.概念题(1)视图是一个虚拟的表,其结构和数据是建立在对表的查询基础上的,也可以说视图的内容由查询定义,而视图中的数据并不像表、索引那样需要占用存储空间,视图中保存的仅仅是一条select语句,其数据来自于视图所引用的数据库表或者其他视图,对视图的操作与对表的操作一样,可以对其进行查询、修改、删除。(2)保护数据安全、简化操作、使分散数据集中、提高数据的逻辑独立性。(3)触发器定义了一系列操作,这一系列操作称为触发程序,当触发事件发生时,触发程序会自动运行。触发器主要用于监视某个表的插入(insert)、更新(update)和删除(delete)等更新操作,这些操作可以分别激活该表的insert、update和delete类型的触发程序运行,从而实现数据的自动维护。(4)触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象在MySQL中,可以使用createtrigger语句创建触发器,具体语法格式为:createtriggertrigger_nametrigger_timetrigger_eventontbl_nameforeachlowtrigger_stmt与其他数据库对象一样,可以使用drop语句将触发器从数据库中删除,语法格式为:droptrigger[schema_name.]trigger_name3.操作题(1)创建一个表tb,其中只有一列a,在表上创建一个触发器,每次插入操作时将用户变量count值增加1。createtabletb(aint);set@count=0;createtriggertb1_insertafterinsertontbforeachrowset@count=@count+1;(2)在(1)基础上,创建一个由delete触发多个执行语句的触发器tb_delete,每次删除记录时,@count记录删除的个数。set@old_value=null,@count=0;delimiter$$createtriggertb_deleteafterdeleteontbforeachrowbeginset@old_value=old.a;set@count=@count+1;end$$delimiter;(3)定义了一个update触发程序,用于检查更新每一行时将使用的新值,并更改值,使之位于0~100内。(提示:它必须是before触发程序,因为需要将值用于更新行之前对其进行检查。)delimiter$$createtriggerudp_checkbeforeupdateontbforeachrowbeginifnew.a<0thensetnew.a=0;elseifnew.a>1100thensetnew.a=100;endif;end;$$delimiter;第6章事务管理实践与练习单选题:BCBCD(6)-(13)ABBBCDAD简答题:事务的开启、回滚和提交命令是什么?使用命令“starttransaction;”可以开启一个事务,该命令开启事务的同时会隐式地关闭MySQL自动提交。当MySQL关闭自动提交后,可以使用COMMIT命令来完成事务的提交。使用rollback命令可以完成事务的回滚,事务的回滚可以撤销未提交的事务所做的各种修改操作,并结束当前这个事务。事务的四大特性及其含义?数据库中的事务具有ACID属性,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持永性(Durability)。原子性意味着每个事务都必须被认为是一个不可分割的单元,事务中的操作必须同时成功事务才是成功的。如果事务中的任何一个操作失败,则前面执行的操作都将回滚,以保证数据的整体性没有受到影响。事务的一致性保证了事务完成后,数据库能够处于一致性状态。如果事务执行过程中出现错误,那么数据库中的所有变化将自动地回滚,回滚到另一种一致性状态。在MySQL中一致性主要由MySQL的日志机制处理,它记录了数据库的所有变化,为事务恢复提供了跟踪记录。如果系统在事务处理中发生错误,MySQL恢复过程将使用这些日志来发现事务是否已经完全成功地执行,是否需要返回。一致性保证了数据库从不返回一个未处理完的事务。事务的隔离性确保多个事务并发访问数据时,各个事务不能相互干扰。系统中的每个事务在自己的空间执行,并且事务的执行结果只有在事务执行完才能看到。即使系统中同时执行多个事务,事务在完全执行完之前,其他事务是看不到结果的。在多数事务系统中,可以使用页级锁定或行级锁定来隔离不同事务的执行。事务的持久性意味着事务一旦提交,其改变会永久生效,不能再被撤销。即使系统崩溃,一个提交的事务仍然存在。MySQL通过保存所有行为的日志来保证数据的持久性,数据库日志记录了所有对于表的更新操作。事务的隔离级别及其含义?事务的隔离级别是事务并发控制的整体解决方案,是综合利用各种类型的锁机制解决并发问题。每个事务都有一个隔离级,它定义了事务彼此之间隔离和交互的程度。在MySQL中提供了4种隔离级别:readuncommitted(读取未提交的数据)、readcommitted(读取提交的数据)、repeatableread(可重复读)和serializable(串行化)。其中,readuncommitted的隔离级别最低,serializable的隔离级别最高,4种隔离级别逐渐增加。readuncommitted(读取未提交的数据):提供了事务之间的最小隔离程度,处于这个隔离级别的事务可以读到其他事务还没有提交的数据。readcommitted(读取提交的数据):处于这一级别的事务可以看见已经提交事务所做的改变,这一隔离级别要低于repeatableread(可重复读)。repeatableread(可重复读):这是MySQL默认的事务隔离级别,它确保在同一事务内相同的查询语句其执行结果总是相同的。serializable(串行化):这是最高级别的隔离,它强制事务排序,使事务一个接一个地顺序执行。什么是脏读、不可重复读和幻读?一个事务可以读到另一个事务未提交的数据则为脏读。如果将事务的隔离级别设置为readuncommitted,则可能出现脏读、不可重复读和幻读等问题。将事务的隔离级别设置为readcommitted则可以避免脏读,但可能出现不可重复读以及幻读等问题。在同一个事务中,两条相同的查询语句其查询结果不一致。当一个事务访问数据时,另一个事务对该数据进行修改并提交,导致第一个事务两次读到的数据不一样。当事务的隔离级别设置为readcommitted时可以避免脏读,但可能会出现不可重复读。将事务的隔离级别设置为repeatableread,则可以避免脏读和不可重复读。幻读是指当前事务读不到其他事务已经提交的修改。将事务的隔离级别设置为repeatableread可以避免脏读和不可重复读,但可能会出现幻读。将事务的隔离级别设置为serializable,可以避免幻读。第7章MySQL连接器JDBC和连接池一、选择题BABCCCBBAB二、简答题1.(1)加载JDBC驱动程序;(2)创建数据库连接;(3)创建Statement对象;(4)执行SQL语句;(5)处理执行SQL语句的返回结果;(6)关闭连接。2.(1)createQuery:针对数据库Select查询;(2)createUpdate:针对数据库新增、删除、修改操作。3.一种是使用Statement对象提供的带参数的executeQuery()方法,另一种是通过PreparedStatement对象提供的无参数的executeQuery()方法。4.数据库连接池就是为数据库连接建立一个“缓冲池”,预先在“缓冲池”中放入一定数量的连接。当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。在Tomcat中配置连接池:(1)将MySQL数据库的JDBC驱动程序包复制到Tomcat安装路径下的lib文件夹中。(2)配置数据源。配置Tomcat根目录下conf文件夹中的文件context.xml,代码如下:<Context><Resourcename="jdbc/datasource"auth="Container"type="javax.sql.DataSource"driverClassName="com.mysql.jdbc.Driver"url="jdbc:mysql://localhost:3306/bookstore"username="root"password="123456"maxActive="8"maxIdle="4"maxWait="6000"/></Context>5.(1)建立与数据库的连接。(2)向数据库发送SQL语句。(3)处理从数据库返回的结果。第8章Hibernate框架介绍选择题:BAB DC B B DCA简答题:1.描述Hibernate工作流程Hibernate工作过程如下:(1)应用程序先调用Configuration类,实例化Configuration类,该类读取Hibernate的核心配置文件hibernate.cfg.xml及映射文件XX.hbm.xml中的信息。(2)创建SessionFactory。通过Configuration对象读取配置文件信息,并创建SessionFactory,并将Configuration对象中的所有配置文件信息存入SessionFactory内存中。(3)创建Session对象。Session是通过SessionFactory对象的openSession()方法创建Session,这样就相当于创建了一个数据库连接的session。(4)创建Transaction实例,即开启一个事务。通过Session对象的beginTransaction()方法即可开启一个事务,利用这的开启的事务,便可以对数据库进行各种持久化操作。(5)利用Session对象通过增删改查等方法对数据库进行各种持久化操作。(6)提交事务。将第(4)步打开的事务通过mit()方法,进行事务的提交(7)关闭Session。断开与数据库的连接。(8)关闭SessionFactory。简述Hibernate持久化操作的主要步骤。Hibernate持久化操作的主要步骤下面四个步骤:导入相关Hibernate的jar包、创建数据库及表、创建实体类(持久化类)、配置映射文件XX.hbm.xml、配置主配置文件hibernate.cfg.,xml、编写数据库操作(增删改查)。举例说明Hibernate的检索方式主要有几种方式:一种get和load方式,一种是使用Query对象和HQL语句进行查询,一种使用criteria进行查询。具体事例见课本。第9章事件和数据管理实践与练习答案1.填空题(1)GLOBALevent_scheduler(2)事件(3)createuser(4)revoke2.选择题(1)D(2)B(3)A(4)A(5)C(6)A(7)B(8)A(9)A(10)D3.概念题(1)查看用户的语法格式如下:select*frommysql.userwherehost=’host_name’anduser=’user_name’删除用户的语法:使用dropuser语句可以删除普通用户,dropuser语句删除用户必须有dropuser权限,语法规则如下:dropuseruser[,user]…(2)使用mysqladmin命令来修改密码,语法规则如下:mysqladmin-uusernameppasswordpassword为关键字使用set语句来修改密码,语法规则如下:setpassword[for’username’@’hostname’]=password(‘new_password’);如果不加[for’username’@’hostname’],则表明修改当前用户密码,如果加了[for’username’@’hostname’],则表明修改当前主机上的特定用户的密码。(3)给予用户授权可以使用grant语句,语法格式如下:grantpriv_type[(column_list)][,priv_type[(column_list)]]…on[object_type]priv_leveltouser_specification[,user_specification]…[withwith_option…](4)当需要撤销一个用户的权限,但不从user表中删除该用户,可以使用revoke语句,语法格式如下:revokepriv_type[(column_list)][,priv_type[(column_list)]]…on[object_type]priv_levelfromuser[,user]…或者revokeallprivieges,grantoptionfromuser[,user]…4.操作题selectcurdate(),current_date(),curtime(),current_time(),now(),current_timestamp(),localtime(),sysdate()\G第10章常见函数和存储过程实践与练习答案1.填空题(1)GLOBALevent_scheduler(2)事件2.概念题(1)查看用户的语法格式如下:select*frommysql.userwherehost=’host_name’anduser=’user_name’删除用户的语法:使用dropuser语句可以删除普通用户,dropuser语句删除用户必须有dropuser权限,语法规则如下:dropuseruser[,user]…(2)使用mysqladmin命令来修改密码,语法规则如下:mysqladmin-uusernameppasswordpassword为关键字使用set语句来修改密码,语法规则如下:setpassword[for’username’@’hostname’]=password(‘new_password’);如果不加[for’username’@’hostname’],则表明修改当前用户密码,如果加了[for’username’@’hostname’],则表明修改当前主机上的特定用户的密码。(3)给予用户授权可以使用grant语句,语法格式如下:grantpriv_type[(column_list)][,priv_type[(column_list)]]…on[object_type]priv_leveltouser_specification[,user_specification]…[withwith_option…](4)当需要撤销一个用户的权限,但不从user表中删除该用户,可以使用revoke语句,语法格式如下:revokepriv_type[(column_list)][,priv_type[(column_list)]]…on[object_type]priv_levelfromuser[,user]…或者revokeallprivieges,grantoptionfromuser[,user]…3.操作题selectcurdate(),current_date(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论