软件项目实践中的SQL语言一瞥
文章平均质量分 84
知识的港湾
高级软件开发工程师
展开
-
让你提前认识软件开发(26):数据库脚本的注释
第2部分 数据库SQL语言数据库脚本的注释 1. 概述 注释在程序语言的编写中占有非常重要的地位。优美的、得当的注释不仅有助于研发人员理解程序,还能够提高编程效率(进而提高办事效率)。 但是,可能是由于工作比较忙的缘故,许多开发人员不重视注释的书写,这也导致了项目交接的时候,其他开发人员理解程序困难,甚至不知道程序到底要做什么事情。因此,良好注释的书写是对一个开发人员的原创 2014-06-02 21:50:11 · 2378 阅读 · 0 评论 -
HBase学习总结(1):HBase的下载与安装
(HBase是一种数据库:Hadoop数据库,它是一种NoSQL存储系统,专门设计用来快速随机读写大规模数据。本文介绍HBase的下载与安装的整个过程。) 一、HBase的下载 1.登录HBase官网http://hbase.apache.org/,可看到如图1所示的页面: 图1 登录HBase官网的页面2.点击图1中的红色小框中的“here”,进入如图2所示的页面。 图2 下载链接原创 2015-06-26 12:16:39 · 4798 阅读 · 0 评论 -
HBase学习总结(2):HBase介绍及其基本操作
(HBase是一种数据库:Hadoop数据库,它是一种NoSQL存储系统,专门设计用来快速随机读写大规模数据。在已成功安装并正常启动的前提下,本文介绍HBase的基本操作。) 一、HBase简介 什么是HBase(Hadoop Database)呢?有以下两种常见的说法: 第一,它是一种稀疏的、分布式的、持久化的、多维有序映射,它基于行键(row key)、列键(column key)和时间戳原创 2015-06-29 14:44:41 · 5079 阅读 · 2 评论 -
NoSQL数据库概览及其与SQL语法的比较
HBase是一个高可靠性、高性能、面向列、可伸缩的分布式存储系统,同时也是知名的NoSQL数据库之一。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用的难题。本文对NoSQL数据库的定义、分类、特征、当前比较流行的NoSQL数据库系统等进行了简单的介绍,并对NoSQL和SQL语法进行了简单的比较,为大家对NoSQL数据库的学习提供了有益的参考。原创 2015-07-02 13:45:33 · 10355 阅读 · 3 评论 -
HBase学习总结(3):HBase的数据模型及工作机制
一、HBase数据模型 HBase模式里的逻辑实体包括: (1)表(table):HBase用表来组织数据。表名是字符串(String),由可以在文件系统路径里使用的字符组成。 (2)行(row):在表里,数据按行存储。行由行键(rowkey)唯一标识。行键没有数据类型,总是视为字节数组byte []。 (3)列族(column family):行里的数据按照列族分组,列族也影响到HBase原创 2015-07-06 19:00:28 · 6427 阅读 · 2 评论 -
Hadoop分布式文件系统HDFS的工作原理详述
Hadoop分布式文件系统(HDFS)是一种被设计成适合运行在通用硬件上的分布式文件系统。HDFS是一个高度容错性的系统,适合部署在廉价的机器上。它能提供高吞吐量的数据访问,非常适合大规模数据集上的应用。要理解HDFS的内部工作原理,首先要理解什么是分布式文件系统。1.分布式文件系统 多台计算机联网协同工作(有时也称为一个集群)就像单台系统一样解决某种问题,这样的系统我们称之为分布式系统。 分布原创 2015-07-16 08:48:21 · 12982 阅读 · 1 评论 -
HBase学习总结(4):HBase的工作原理
一、切分和分配大表 HBase中的表是由行和列组成的。HBase中的表可能达到数十亿行和数百万列。每个表的大小可能达到TB级,有时甚至PB级。这些表会切分成小一点儿的数据单位,然后分配到多台服务器上。这些小一点儿的数据单位叫region。托管region的服务器叫RegionServer。一张表由多个小一点的region组成,如图1所示。 图1 多个小一点的region组成一张表 Regi原创 2015-07-17 17:29:46 · 3580 阅读 · 0 评论 -
HBase学习总结(5):HBase表设计
HBase学习总结第五篇原创 2015-08-03 19:10:22 · 10837 阅读 · 5 评论 -
ORACLE调用接口(OCI)简介及重要函数流程介绍
对于实现用户开销户的程序来说,与数据库进行交互是必不可少的。为了实现用户数据的存放、读取、删除等操作,我们需要频繁地访问数据库,这就对数据库的访问模式提出了较高的要求。ORACLE数据库具有系统可移植性好、使用方便、功能强等特点,因此在实际的软件开发项目中使用得非常的广泛。本文首先简单介绍了OCI的基本情况,然后对OCI中两个重要的程序流程进行了一定的介绍。希望大家通过此文,能够对OCI有一个大致的了解。原创 2015-12-07 18:45:26 · 12693 阅读 · 2 评论 -
MySQL数据库移植总结
本文基于作者近期将Sybase数据库移植为MySQL数据库的工作,总结了在移植过程中需要修改的主要数据库语法及一些基本的操作MySQL的命令。原创 2016-04-28 18:56:47 · 8970 阅读 · 0 评论 -
在测试MySQL脚本时所遇到的问题
近期,笔者在做MySQL脚本的移植和测试工作。在此过程中,发现了MySQL数据库所存在的一些有待优化的地方,特写下此文,供相关项目的开发人员参考。原创 2016-06-02 18:59:21 · 3594 阅读 · 2 评论 -
存储过程测试流程--以MySQL为例
同C/C++/Java等语言编写的代码一样,用SQL语言编写的存储过程也需要进行充分的测试。本文以实际的MySQL存储过程为例,介绍存储过程测试的整个流程。原创 2016-06-06 18:58:06 · 11404 阅读 · 2 评论 -
常用的数据库索引优化语句总结
近期,我们对之前编写的数据库脚本进行了全面的自查,从数据库的性能方面考虑,将脚本里面的很多SQL语句进行了优化。对于一条SQL语句来说,索引的使用是否正确将直接影响到数据库的性能,因此,对索引使用方法的优化是数据库性能优化的重点。本文对常用的数据库索引优化语句进行了总结,可供相关的开发人员参考。原创 2016-07-18 21:51:42 · 10192 阅读 · 2 评论 -
对一个MySQL存储过程的优化
在编写MySQL存储过程的过程中,我们会时不时地需要对某些存储过程进行优化,其目的是确保代码的可读性、正确性及运行性能。本文以作者实际工作为背景,介绍了对某一个MySQL存储过程优化的整个过程。原创 2016-06-23 21:47:53 · 8815 阅读 · 0 评论 -
基于ORACLE数据库的循环建表及循环创建存储过程的SQL语句实现
一、概述 在实际的软件开发项目中,我们经常会遇到需要创建多个相同类型的数据库表或存储过程的时候。例如,如果按照身份证号码的尾号来分表,那么就需要创建10个用户信息表,尾号相同的用户信息放在同一个表中。 对于类型相同的多个表,我们可以逐个建立,也可以采用循环的方法来建立。与之相对应的,可以用一个存储过程实现对所有表的操作,也可以循环建立存储过程,每个存储过程实现对某个特定表的操作。 本文中,我们原创 2015-06-03 13:50:01 · 5852 阅读 · 0 评论 -
ORACLE和SYBASE数据库中实现数据查询条数限制的SQL语句实现
一、概述 对于某些需要通过数据库与大量数据打交道的软件来说,处理性能相当的重要。为了保证软件能够将所有数据处理完而不至于崩溃,分批处理的思想应运而生。分批处理的具体做法是编写SQL语句,每次返回规定条数的数据给软件处理,待这一批数据处理完之后,再接着处理下一批。 本文通过对具体的数据库表(tb_employeeinfo)的操作过程,展示了ORACLE和SYBASE数据库中分批处理SQL语句的编写原创 2015-05-18 18:50:43 · 5960 阅读 · 4 评论 -
让你提前认识软件开发(30):数据库脚本中的空行与空格
第2部分 数据库SQL语言数据库脚本中的空行与空格 在数据库脚本中,空行与空格起着“锦上添花”的作用。恰当地使用它们,可以提高代码的规范性及可阅读性,进而提升数据库的编程效率。 1. 空行 空行起着分隔脚本段落的作用,适当的空行可以使脚本的布局更加的清晰。空行的作用有以下几个: (1) 用于分隔两个数据表的创建脚本 示例:create t原创 2014-06-22 21:55:32 · 2383 阅读 · 0 评论 -
让你提前认识软件开发(31):数据库脚本中的begin与end
第2部分 数据库SQL语言数据库脚本中的begin与end 在数据库脚本中,begin与end是一对奇怪的单词。缺少它们,某些代码看起来会让人一头雾水;添加它们,代码的结构瞬间就清晰了。 确实,begin与end作为代码语句的开始和结束标志,可以让脚本程序的逻辑明确,易于阅读。 begin与end主要用在以下地方: 1. if、else、e原创 2014-06-25 21:01:18 · 3894 阅读 · 0 评论 -
让你提前认识软件开发(27):数据库表及索引的创建
第2部分 数据库SQL语言数据库表及索引的创建 数据表(或称表),是数据库最重要的组成部分之一。数据库只是一个框架,数据表才是其实质的内容。举个例子来说,数据库就像是一座空旷的房子,而数据表是里面的家具,没有家具的房子只是一个空壳而已。根据信息的分类情况,一个数据库中可能包含若干个不同用途的数据表。 表结构有简单、有复杂,这就对开发人员提出了要求。如何设计一个表的字段原创 2014-06-09 20:51:22 · 1942 阅读 · 0 评论 -
让你提前认识软件开发(32):数据库索引
第2部分 数据库SQL语言数据库索引 索引在数据库中占有非常重要的地位,它是对数据库表中一列或多列的值进行排序的一种结构。正确使用索引,可快速访问数据库表中的特定信息,进而提高数据库脚本的执行效率。 1. 索引分类 数据库表中经常有一列或几列的组合,其值唯一地标识表中的每一行,该列称为表的主键。 在数据库中,将索引分为三类:唯一索引、主键索引和聚集索引。原创 2014-06-29 17:18:58 · 2125 阅读 · 0 评论 -
让你提前认识软件开发(28):数据库存储过程中的重要表信息的保存及相关建议
第2部分 数据库SQL语言数据库存储过程中的重要表信息的保存及相关建议 1. 存储过程中的重要表信息的保存 在很多存储过程中,会涉及到对表数据的更新、插入或删除等,为了防止修改之后的表数据出现问题,同时方便追踪问题,一般会为一些重要的表建立一个对应的debug表。这个debug表中的字段要包括原表的所有字段,同时要增加操作时间、操作码和操作描述等字段信息。 例如,在某项原创 2014-06-11 21:03:32 · 1973 阅读 · 0 评论 -
让你提前认识软件开发(25):数据库简介
第2部分 数据库SQL语言数据库简介 数据库是个通用化的综合性的数据集合,它可以供各种用户共享且具有最小的冗余度和较高的数据与程序的独立性。目前,国际上主导的大型数据库管理系统有ORACLE、SQL SERVER、SYBASE、INFORMIX和INGRES等。 数据库中常用的编程语言是SQL语言,按其功能可分为四大部分: (1) 数据定义语言(Data原创 2014-05-29 18:50:12 · 2689 阅读 · 1 评论 -
让你提前认识软件开发(33):数据操纵语言(DML)
第2部分 数据库SQL语言数据操纵语言(DML) 数据操纵语言(Data Manipulation Language,DML)包括insert、delete和update语句,用于增、删、改数据。 本文用以下的表tb_employeeinfo作为例子加以说明:create table tb_employeeinfo( employeeno var原创 2014-07-02 18:50:05 · 1728 阅读 · 0 评论 -
让你提前认识软件开发(34):数据库的维护
第2部分 数据库SQL语言数据库的维护 对于某些大型软件产品,一旦商用,必然会存储很多用户信息,这就对产品所使用的数据库(以下简称业务数据库)带来了压力。为了保证业务数据库的平稳运行,需要在日常工作中对数据库做一些基本的维护操作。 业务数据库的维护规则如下:1. 对业务数据库必须进行定期全量备份 业务数据库的定期备份能在数据库被意外破坏时进行快速恢复,备原创 2014-07-06 23:04:43 · 1995 阅读 · 0 评论 -
让你提前认识软件开发(29):数据库脚本文件的布局
第2部分 数据库SQL语言数据库脚本文件的布局 “没有规矩,不成方圆”,规范数据库脚本文件的代码布局具有以下重要意义: (1) 可表现出代码良好的逻辑结构,提高代码的准确性、连续性、可读性及可维护性。 (2) 有利于提高产品的开发质量和效率,并降低开发成本。 (3) 对于开发人员来说,养成良好的脚本编写习惯有助于提高个人的数据库脚本编程水平,原创 2014-06-16 22:49:14 · 1885 阅读 · 0 评论 -
让你提前认识软件开发(35):如何修改SQL脚本以完成需求?
第2部分 数据库SQL语言如何修改SQL脚本以完成需求? SQL脚本的修改和C语言代码的修改流程是一样的,都要遵循以下步骤: 第一步,阅读需求,弄清楚自己要完成什么功能。 第二步,对照需求阅读原代码,找到本次要修改的内容的大致位置。 第三步,对代码进行修改(包括:添加、删除和修改等),将本次的功能添加上去。 第四步,对修改后原创 2014-07-09 20:34:47 · 1881 阅读 · 0 评论 -
让你提前认识软件开发(36):如何扩展数据表字段?
第2部分 数据库SQL语言如何扩展数据表字段? 【文章摘要】 在通信类软件中,经常会与数据库打交道。由于需求变化,或者是程序优化升级等原因,对数据表字段进行扩展是常有的事情。这就要求开发人员必须熟练掌握对数据表字段进行扩展的操作流程。 本文基于作者的数据库方面的工作经验,以实际的SQL程序为例,详细介绍了如何对对数据表字段进行扩展,为相关的开发工作提供了参考。【关键词】原创 2014-07-13 21:05:45 · 2063 阅读 · 0 评论 -
如何描述一张数据表的基本信息?
最近,我和一位同事合作设计数据库表。我们在设计好各个表之后,需要将表的基本信息记录下来,发给同项目组的同事参阅和评审。最开始,我们不是很清楚如何来描述每张表的信息。通过与大家商量之后,我们认为通过如下格式描述数据库表的基本信息比较恰当。本文的可供有类似需求的开发人员参考。要比较完整地描述一张数据表,需要交代清楚这五个部分:总体说明、版本说明、表结构说明、建表脚本、初始化语句。以下以员工信息表为例加原创 2015-04-10 16:26:57 · 16569 阅读 · 2 评论 -
动态内存分配的C代码示例
之前有同学在QQ上问我,C语言中的动态内存分配是怎么回事。首先,我们来看看内存分配的概念,它是指在程序执行的过程中分配或者回收存储空间的方法。一般说来,内存分配方法分为静态内存分配和动态内存分配两种。在本文中,我们主要讨论动态内存分配。原创 2016-09-02 20:58:05 · 6538 阅读 · 6 评论