您好,欢迎来到思海网络,我们将竭诚为您提供优质的服务! 诚征网络推广 | 网站备案 | 帮助中心 | 软件下载 | 购买流程 | 付款方式 | 联系我们 [ 会员登录/注册 ]
促销推广
客服中心
业务咨询
有事点击这里…  531199185
有事点击这里…  61352289
点击这里给我发消息  81721488
有事点击这里…  376585780
有事点击这里…  872642803
有事点击这里…  459248018
有事点击这里…  61352288
有事点击这里…  380791050
技术支持
有事点击这里…  714236853
有事点击这里…  719304487
有事点击这里…  1208894568
有事点击这里…  61352289
在线客服
有事点击这里…  531199185
有事点击这里…  61352288
有事点击这里…  983054746
有事点击这里…  893984210
当前位置:首页 >> 技术文章 >> 文章浏览
技术文章

编写可重用的MySQL查询

添加时间:2011-1-13  添加: admin 

当人们提及可重用的查询的时候,立即映入脑海的往往就是存储过程了。虽然这些存储过程是编写可重用代码不可分割的一部分,但要记住的是,它们只是很少的一部分而已,而非全部。此外,其它可重用代码包括视图、内置函数以及用户定义的函数。在本文中,我们将向读者详细介绍如何组合这些元素,以令我们的选择语句可以更好的适用于各种查询。

  一、关于视图

  视图的用途很多,例如简化复杂的模式及查询,或者提供安全性等等。视图提供安全性的一种途径是对开发者隐藏审计字段。视图还可通过减少列的数目来提高性能。这个想法是只引用索引字段,而索引字段的搜索速度是非常之快的。实际上,这种想法实现起来很费劲,因为你必须确保不会访问隐藏列。然而,我们这里主要是利用视图模拟两个或更多个表之间的连接,以降低查询的复杂性。很多时候,要想将数据库中用户的概要信息整理成符合第三范式的形式,可能需要多达六次连接操作,例如:

select *
from   Users u
  inner join UserPhoneNumbers upn on u.user_id          = upn.user_id
  inner join UserScreenNames  usn on u.user_id          = usn.user_id
  inner join UserAffiliations ua  on u.user_id          = ua.user_id
  inner join Affiliations     a   on a.affiliation_id   = ua.affiliation_id
  inner join UserWorkHistory  uwh on u.user_id          = uwh.user_id
  inner join Affiliations     wa  on uwh.affiliation_id = wa.affiliation_id
   下面,我们用一个视图来替换上面的查找过程:

CREATE VIEW `vusers` AS
  select *
  from   Users u
    inner join UserPhoneNumbers upn on u.user_id          = upn.user_id
    inner join UserScreenNames  usn on u.user_id          = usn.user_id
    inner join UserAffiliations ua  on u.user_id          = ua.user_id
    inner join Affiliations     a   on a.affiliation_id   = ua.affiliation_id
    inner join UserWorkHistory  uwh on u.user_id          = uwh.user_id
    inner join Affiliations     wa  on uwh.affiliation_id = wa.affiliation_id;
   现在,我们可以通过以下简单的选择语句来检索用户概要信息了:

select *
from   vusers u
where  u.user_id = 100

关健词:MYSQL

分享到:

顶部 】 【 关闭
版权所有:佛山思海电脑网络有限公司 ©1998-2024 All Rights Reserved.
联系电话:(0757)22630313、22633833
中华人民共和国增值电信业务经营许可证: 粤B1.B2-20030321 备案号:粤B2-20030321-1
网站公安备案编号:44060602000007 交互式栏目专项备案编号:200303DD003  
察察 工商 网安 举报有奖  警警  手机打开网站