2023年计算机二级MySQL数据库程序设计知识点总结.docx
《2023年计算机二级MySQL数据库程序设计知识点总结.docx》由会员分享,可在线阅读,更多相关《2023年计算机二级MySQL数据库程序设计知识点总结.docx(19页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、MySQL知识点总结.数据操作:检索、排序、过滤、分组、汇总、计算、联接、子查询与组合查询.表操作:表的创建、修改、删除和重命名、表数据的插入、更新和删除.索引(含主、外键)、视图.难度编程:存储过程与存储函数、触发器与事件、PHP.数据库管理:事务解决、用户与权限、备份与还原、数据库维护1. 检索数据:selectfromSelect distinct prod_id,prod_name from products limit 4,5;2. 检索排序:order bySelect * from products order by prod_id asc|desc,prod_name asc|
2、desc;3. 过滤数据:where 字句= != = 1000 group by prod_id having count(prod_id)2 order by prod_id;求出prod_id大于1000且产品数量大于2的产品数量,并按prod_id排序,注意分组语句中对象要前后一致,如下划线部分。7. 使用子查询:进行过滤selectwherein(selectwherein(select)、作为计算字段使用子查询。8. 联接:joinon(1)普通联接Select oi.order_num,oi.prod_id,p.prod_name,p.vend_id,v.vend_name fr
3、om orderitems oi join products p on oi.prod_id=p.prod_id join vendors v on p.vend_id=v.vend_id where vend_name=liyang;可同时联接多个表且可同时用于数据过滤,这种类型的联接一般为内部联接。(2)自联接:一个表自己与自己联接,注意判断好各字段与前后两个表的关系。(3)自然联接:基本上简历的内部联接都是自然联接。(4)外部联接:在关系表中没有关联的信息的行也能显示出来的联接,根据表在join字句的左边还是右边可分为左联接与右联接。(5)带聚集函数的联接 Select c.cust_i
4、d,count(o.order_num) num_ord from customers c join orders o on c.cust_id=o.cust_id order by c.cust_id;找出客户相应的订单数。9. 组合查询:连接多个(至少两个)查询语句,满足其中一个查询语句条件的结果都会显示出来 union(不反复显示)/union all (可反复显示即所有显示)Select vend_id,prod_id,prod_price from products where prod_price=5Union allSelect vend_id,prod_id,prod_pric
5、e from products where vend_id in(1001,1002) order by prod_id;注意每个查询必须包含相同的列、表达式或者聚集函数,列的数据类型必须兼容,排序语句只能放在最后面,该排序语句对组合查询语句中的所有select语句都合用。10. 全文本搜索:只支持引擎为MyISAM的表,不支持引擎为InnoDB的表,可对搜索结果进行智能排序后输出,具有较高等级的行先返回。Match(全文本搜索字段) against(全文本搜索内容 with query expansion)其中下划线部分为拓展语句,使用该语句,除了可以返回符合所设立的“全文本搜索内容”的数据
6、结果,还可返回与“全文本搜索内容”有较高相似度的数据结果。(1)启用全文本搜索支持Create table fs(id int not null primary key,c text,c1 text,fulltext(c,c1) engine=MyISAM;(2)进行全文本搜索 Select note_text from productnotes where match(note_text) against(liyang with query expansion);11. 插入数据:insert intovalues|selectInsert into products(prod_id,pro
7、d_name,prod_price) values(1,豆浆,2),(3,鸡蛋,1);可同时插入多行数据。Insert into products(prod_id,prod_name,prod_price) select vend_id,vend_name,vend_price from vendors where vend_id1000;13. 删除数据:delete fromDelete from products where prod_id between 10 an 50;14. 表的相关操作(1)创建表:对表结构进行设立create tableCreate table product
8、s(prod_id int null auto_increment primary key,prod_name varchar(50),prod_price int,prod_city varchar(50) default 广州) engine=InnoDB;每个字段名后需要设立数据类型,default为指定默认值,只支持常量不支持函数,且只在插入数据时起作用而在更新数据时不起作用,InnoDB是一个可靠的事务解决引擎,但不支持全文本搜索。(2)更新表:对表结构进行修改 alter table add|dropAlter table products add prod_city varcha
9、r(50);Alter table products drop prod_price;(3)删除表:一旦删除,无法撤消 drop tableDrop table products;(4)重命名表:rename tabletoRename table products to new_products;15. 索引的相关操作(1)创建索引:常用于数据的快速检索,MySQL中,常用索引在物理可分为:BTREE、HASH索引两类;在具体用途上可分为:INDEX、UNIQUE、PRIMARY KEY、FOREIGN KEY、FULL TEXT、SPATIAL等。使用create index 语句创建索引
10、,对已存在的表创建索引Create unique|fulltext|spatial index index_name using BTREE|HASH on tbl_name(index_col_name,index_col_name);Create unique index index_products on products(prod_name(2) desc,prod_price);使用create table 语句创建索引,创建表的同时创建索引 Create table seller(seller_id int not null auto_increment,seller_name c
11、har(50),seller_adress char(50),seller_contact char(50),product_type int,sales int,primary key(seller_id,product_type),unique|fulltext|spatial index index_seller(sales);使用alter table语句创建索引,修改表的同时添加索引 Alter table tbl_name add unique|fulltext|spatial index index_tbl_name(字段名)|primary key(字段名)|foreign k
12、ey(字段名)references elsetbl_name(相同字段名);(2)查看索引:Show index from tbl_name where expr;(3)删除索引:drop index index_name on tbl_name语句或alter table语句Drop index index_name on tbl_name;Alter table tbl_name drop unique|fulltext|spatial index index_tbl_name(字段名)|primary key(字段名)|foreign key(字段名)references elsetbl
13、_name(相同字段名;(下划线部分不拟定)16. 视图的相关操作视图:虚拟的表,视图自身不包含表中的列和数据,它包含只是一个SQL查询,常用于检索数据。*视图的作用与规则。(1)创建视图:Create view view_name as selectwhere;Create view view_products as select prod_id,prod_name,prod_price,prod_num,prod_price*prod_num as prod_money from products where prod_id=10 with check option;- 下划线部分表达此后
14、对该视图数据的修改都必须符合prod_idDelimiter / - 改变分割符为/-create procedure ordertotal(in o_id int,out o_total decimal(10,2) 过程名字 输入参数及类型 输出参数及类型-begin-select sum(item_price*item_num) from orderitems where item_id=o_id into o_total;-if o_total is null then-select 不存在该订单号;-end if;-end;-/- 执行存储过程:当item_id=202305时,得出相
15、应订单总金额-delimiter ; - 将分割符改回分号-call ordertotal(202305,total); - 由于不存在输出参数,故定义一个输出变量,变量必须用开头-select total;返回结果为149.87备注:书本第十一章后的编程题,使用update语句,两个参数类型都需要为in。- 显示存储过程-Show create procedure ordertotal; - 删除存储过程 -Drop procedure ordertotal;21. 存储函数存储函数与存储过程的区别:.存储函数不能拥有输出参数;.存储函数可直接调用,且不需使用call语句,而存储过程的调用必
16、须使用call语句;.存储函数中必须包含一条return语句,而这条特殊的SQL语句不允许包含于存储过程。 - 建立存储函数:根据给定的cust_id返回客户所在的州名(缩写),若库中无给定的cust_id,则返回“不存在该客户”。 -delimiter /-create function fn_search(c_id int)-returns varchar(50) - 定义返回的数据类型,与函数部分中的数据类型需统一,如函数中的“不存在该客户”为6个字符,假如这里设立为char(5),则无法输出该结果-deterministic 表达对于相同的输入值,返回值也相同-begin-declar
17、e state char(2); - 声明一个变量state,作为输出的州变量-select cust_state from customers where cust_id=c_id into state;-if state is null then-return(select 不存在该客户); -注意这里return不用加s-else-return(select state);-end if;-end;-/- 执行存储函数-select fn_search(10001);- 删除存储函数-drop function fn_search; - 删除前要拟定该函数无依赖关系,即不存在其他存储过程
18、或存储函数调用过该存储函数。22. 触发器:MySQL响应insert、delete、update语句时自动执行的一条MySQL语句,创建触发器时需要给出的4条信息:唯一的触发器名、触发器相关的表、触发器应当响应的活动(insert delete、update)、触发器何时执行(解决前或解决后)。(1)insert触发器:当对表插入数据时起作用,具有一个虚拟表New,可访问增长的行,只能用after- 建立一个insert触发器,用于记录insert语句操作时的系统时间和插入的order_num-delimiter /-create trigger trg_order_insert after
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2023 计算机 二级 MySQL 数据库 程序设计 知识点 总结
限制150内