数据库相关 - 军军小站|张军博客
SqlServer

SQL Server 2008 性能调优 optimize for ad hoc

参数化和即席查询,都是一个二难的选择。一旦选择参数化就有可能带来一种情况就是执行计划反复被利用。不会通过收集现有的统计信息,出一个比较优异的执行计划。即席查询也就是adhocquery,每次都需要重编译,花费比较大。这个是一个2难,需要平衡。对于这个问题sqlserver有简单参数化,强制参数化和2008才有的optimizeforadhocworkloads。optimizeforadhocworkloads的原理大概如此:当你第一次执行adhoc查询的

系统 2019-08-12 01:33:33 2221

数据库相关

一种版本化的数据库脚本管理机制

现今开发的软件当中,多数系统的数据都是基于数据库存储的,但是由于软件变化的复杂性,相对于维护代码,数据库架构的版本并不是那么好维护。这里本人针对实际情况,理想化出一种可以清晰理解的数据库架构脚本的版本控制机制。请先看目录树:Example.DataSchema├─V1.0│├─Common││001.Create.Table.Product.sql││002.Create.Table.User.sql││003.Create.Table.Feedback.

系统 2019-08-12 01:32:49 2221

数据库相关

mongodb之基础操作

1,安装:以我本机为例:1)命令安装方式:1.1将下载下来的压缩包解压到D:\Installed\MongoDB下面。1.2以管理员方式打开命令提示符,将目录切换到D:\Installed\MongoDB\bin下面(也可以通过设置环境变量,这样就不用切换目录了)。1.3运行下面的命令mongod--dbpathD:\Installed\MongoDB\data\db--logpathD:\Installed\MongoDB\log\mylog.log--

系统 2019-08-12 01:53:35 2220

Oracle

Oracle 数据库学习一

1.Oracle的开始1977年创立,2002年4月6日在国注册为“甲骨文”2.oracle的版本8i,9i,10g,11g其中i为internet学习用oracle10g3.关系数据库oracle的特点a.支持多用户、大事务量的事务处理b.在保持数据安全性和完整性方面性能优越c.支持分布式数据处理d.可移植性4.oracle的基本概念a.数据库oracle的专业名称,它是磁盘上存储数据的集合,在物理上表现为数据文件,日志文件和控制文件等,在逻辑上以表空间

系统 2019-08-12 01:53:18 2220

Oracle

Oracle悲观锁和乐观锁

为了得到最大的性能,一般数据库都有并发机制,不过带来的问题就是数据访问的冲突。为了解决这个问题,大多数数据库用的方法就是数据的锁定。数据的锁定分为两种方法,第一种叫做悲观锁,第二种叫做乐观锁。什么叫悲观锁呢,悲观锁顾名思义,就是对数据的冲突采取一种悲观的态度,也就是说假设数据肯定会冲突,所以在数据开始读取的时候就把数据锁定住。而乐观锁就是认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果发现冲突了,则让用户

系统 2019-08-12 01:53:18 2220

数据库相关

VC DLL方法的__declspec导入导出

https://msdn.microsoft.com/zh-cn/library/a90k134d.aspxhttps://msdn.microsoft.com/zh-cn/library/ms235636.aspx可以使用两种方法将公共符号导入到应用程序中或从DLL导出函数:生成DLL时使用模块定义(.def)文件__declspec(dllimport)or__declspec(dllexport)i

系统 2019-08-12 01:51:27 2220

MySql

mysql数据库安装图解

下面的是MySQL安装的图解,用的可执行文件安装的,详细说明了一下!打开下载的mysql安装文件mysql-5.0.27-win32.zip,双击解压缩,运行“setup.exe”,出现如下界面mysql安装向导启动,按“Next”继续选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,我们选择“Custom”,有更多的选项,也方便熟悉安装过程:在“DeveloperComponents(开发者

系统 2019-08-29 23:13:29 2219

Oracle

ORACLE纵向表转换为横向表写法

假设存在如下纵向表,第一列为id(可能是某个业务数据的id),第二列为类型,第三列为类型对应的值,如下图:如上表,存在2,3,4三种类型,其中业务数据ID为1的三种类型都有值,业务数据ID为2的三种类型都有值,业务数据ID为3的只有类型2和3有值,现在要把纵向表横过来显示,可以采用如下代码:--=========================================================--纵向表变横向表:--1.转换类型,类型的值必须

系统 2019-08-12 01:55:22 2219

数据库相关

pl/sql中的异常处理

pl/sql中的异常是用exceptionwhenothersthen进行捕获的,一般放在pl/sql块的最后,用户捕获pl/sql中发生的错误,对异常的处理分为两种:1.阻断程序式exceptionwhenothersthenraise_application_error(-20001,'请输入正确的参数!');一般用于数据录入保存时进行校验,校验不合格给出提示。2.非阻断程序式exceptionwhenothersthenl_desc:=sqlerrm

系统 2019-08-12 01:54:48 2219

MySql

mysql初识之数据文件及其他文件

在mysql中数据文件存放于在my.cnf中datadir指定的路径,使用的表引擎不同产生的文件格式、表文件个数也会有所差异。mysql的表引擎有多种,表的扩展名也不一样,如innodb用“.ibd”,archive用“.arc”,csv用“.csv”等。myisam表引擎myisam表会产生三个文件:MYI、MYD、frm文件frm文件:主要存放表的元数据(meta),包括表结构定义信息等。不论是哪个表引擎都会有一个frm文件,存放在数据库的数据目录下。

系统 2019-08-12 01:54:46 2219

Oracle

oracle_constraint的用处

ql中constraint主要是增加约束这个主要就是增加约束的以下几种约束、并一一列举:1.主键约束:主键约束:就是对一个列进行了约束,约束为(非空、不重复)要对一个列加主键约束的话,这列必须满足条件非空,这样才可以约束以下是代码要对一个列加主键,列名为id,表名为emp格式为:altertable表格名称addconstraint约束名称增加的约束类型(列名)例子:altertableempaddconstraintpppprimarykey(id)2.

系统 2019-08-12 01:54:42 2219

数据库相关

Binary Tree Preorder Traversal

二叉树的前序遍历递归实现/***Definitionforbinarytree*structTreeNode{*intval;*TreeNode*left;*TreeNode*right;*TreeNode(intx):val(x),left(NULL),right(NULL){}*};*/classSolution{public:voidPreOrder(TreeNode*root,vector&vec){if(root!=NULL){vec.

系统 2019-08-12 01:52:42 2219

SqlServer

SQL Server数据库优化方案

查询速度慢的原因很多,常见如下几种:1、没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷)2、I/O吞吐量小,形成了瓶颈效应。3、没有创建计算列导致查询不优化。4、内存不足5、网络速度慢6、查询出的数据量过大(可以采用多次查询,其他的方法降低数据量)7、锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷)8、sp_lock,sp_who,活动的用户查看,原因是读写竞争资源。9、返回了不必要的行和列10、查询语句不好,没有优化可以通过如

系统 2019-08-12 01:51:51 2219

Oracle

Oracle 用户(user)和模式(schema)的区别

原文:Oracle用户(user)和模式(schema)的区别概述:(一)什么Oracle叫用户(user):Auserisanamedefinedinthedatabasethatcanconnecttoandaccessobjects.大意:Oracle用户是用连接数据库和访问数据库对象的。(用户是用来连接数据库访问数据库)。(二)什么叫模式(schema):Aschemaisacollectionofdatabaseobjects(usedbyaus

系统 2019-08-12 01:34:00 2219

SqlServer

使用Power Design和SQL Server来做反向工程

PowerDesign(以下简称PD)以其强大的数据库设计功能,以及可以把设计的模型生成数据库脚本或是数据库,使它在软件的开发中应用得很广泛。但是当只有一个现有的数据库而没有数据库设计文档的时候,往往让人无所适从,所以这里讲一下如何使用PD来对数据库进行反向工程,这里使用的是SQLServer不知道其它数据库可不可以的?第一步,对要进行反向工程的库创建一个数据源。在控制面板->管理工具->数据源(ODBC)里面,选择系统DSN选项卡,点击添加按钮,根据向导

系统 2019-08-12 01:33:10 2219