分类目录归档:数据库

/zz/MySQL 常见的数据存储引擎的介绍和应用

以下的文章主要讲述的是MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述,希望你浏览完此文章你会在选择数据库存储引擎时带来一些帮助。以下就是文章的具体内容。

MySQL有多种存储引擎:

MyISAM、InnoDB、MERGE、MEMORY(HEAP)、BDB(BerkeleyDB)、EXAMPLE、FEDERATED、ARCHIVE、CSV、BLACKHOLE。

MySQL支持数个存储引擎作为对不同表的类型的处理器。MySQL存储引擎包括处理事务安全表的引擎和处理非事务安全表的引擎:

继续阅读

/zz/MySQL数据库Concat和outfile函数妙用

大家有没有接触过这样的需求,采集历史数据库中或者其他数据库中的某些信息,这些信息是另一个服务器需要执行sql的条件。通常我们的处理手段是把这个信息通过sql找出来或导出,然后使用脚本或者手工拼凑新的新的sql语句。在很多紧急情况下(产品bug、数据错乱)会产生这样的需求,这个时候处理的是在线数据库,不能有一点马虎、如果数据量稍微大一点,DBA们就够焦头烂额了。我之前也多次遇见这种情况,我把一些经验介绍给大家。

继续阅读

oracle和 mysql的几点区别/zz/

Oracle数据库与MySQL数据库的区别是本文我们主要介绍的内容,希望能够对您有所帮助。

1.组函数用法规则

mysql中组函数在select语句中可以随意使用,但在oracle中如果查询语句中有组函数,那其他列名必须是组函数处理过的,或者是group by子句中的列否则报错

eg:

select name,count(money) from user;这个放在mysql中没有问题在oracle中就有问题了。

2.自动增长的数据类型处理

MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。ORACLE没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。

CREATE SEQUENCE序列号的名称(最好是表名+序列号标记)INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;

其中最大的值按字段的长度来定,如果定义的自动增长的序列号NUMBER(6),最大值为999999

INSERT语句插入这个字段值为:序列号的名称.NEXTVAL

3.单引号的处理

MYSQL里可以用双引号包起字符串,ORACLE里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。

4.翻页的SQL语句的处理

MYSQL处理翻页的SQL语句比较简单,用LIMIT开始位置,记录个数;PHP里还可以用SEEK定位到结果集的位置。ORACLE处理翻页的 SQL语句就比较繁琐了。每个结果集只有一个ROWNUM字段标明它的位置,并且只能用ROWNUM<100,不能用ROWNUM>80。

以下是经过分析后较好的两种ORACLE翻页SQL语句(ID是唯一关键字的字段名):

语句一:

SELECT ID, [FIELD_NAME,…] FROM TABLE_NAME WHERE ID IN ( SELECT ID FROM (SELECT ROWNUM AS NUMROW, ID FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3;

语句二:

SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (select [FIELD_NAME,…] FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) c) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3;

5.长字符串的处理

长字符串的处理ORACLE也有它特殊的地方。INSERT和UPDATE时最大可操作的字符串长度小于等于4000个单字节,如果要插入更长的字 符串,请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包。插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和 超出长度字段值都应该提出警告,返回上次操作。

6.日期字段的处理

MYSQL日期字段分DATE和TIME两种,ORACLE日期字段只有DATE,包含年月日时分秒信息,用当前数据库的系统时间为 SYSDATE,精确到秒,或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)年-月-日24小时:分 钟:秒的格式YYYY-MM-DD HH24:MI:SS TO_DATE()还有很多种日期格式,可以参看ORACLE DOC.日期型字段转换成字符串函数TO_CHAR(‘2001-08-01’,’YYYY-MM-DD HH24:MI:SS’)

日期字段的数学运算公式有很大的不同。MYSQL找到离当前时间7天用DATE_FIELD_NAME > SUBDATE(NOW(),INTERVAL 7 DAY)ORACLE找到离当前时间7天用 DATE_FIELD_NAME >SYSDATE – 7;

MYSQL中插入当前时间的几个函数是:NOW()函数以`’YYYY-MM-DD HH:MM:SS’返回当前的日期时间,可以直接存到DATETIME字段中。CURDATE()以’YYYY-MM-DD’的格式返回今天的日期,可以 直接存到DATE字段中。CURTIME()以’HH:MM:SS’的格式返回当前的时间,可以直接存到TIME字段中。例:insert into tablename (fieldname) values (now())

而oracle中当前时间是sysdate

7.空字符的处理

MYSQL的非空字段也有空的内容,ORACLE里定义了非空字段就不容许有空的内容。按MYSQL的NOT NULL来定义ORACLE表结构,导数据的时候会产生错误。因此导数据时要对空字符进行判断,如果为NULL或空字符,需要把它改成一个空格的字符串。

8.字符串的模糊比较

MYSQL里用字段名like%‘字符串%’,ORACLE里也可以用字段名like%‘字符串%’但这种方法不能使用索引,速度不快,用字符串比较函数instr(字段名,‘字符串’)>0会得到更精确的查找结果。

9.程序和函数里,操作数据库的工作完成后请注意结果集和指针的释放。

Linux下oracle数据库启动和关闭操作

第一步:登陆
root登陆之后切换到oracle用户上,输入

  1. su oracle

su oracle
第二步:连接
在oracle用户下,输入

  1. sqlplus /nolog

sqlplus /nolog
第三步:使用管理员权限
输入

  1. connect /as sysdba

connect /as sysdba
第四步:启动/关闭服务
输入

  1. startup

startup
startup参数
不带参数,启动数据库实例并打开数据库,以便用户使用数据库,在多数情况下,使用这种方式!
nomount,只启动数据库实例,但不打开数据库,在你希望创建一个新的数据库时使用,或者在你需要这样的时候使用!
mount,在进行数据库更名的时候采用。这个时候数据库就打开并可以使用了!
谢谢!不准确的地方请指教!
继续阅读

PL/SQL与T-SQL的区别

PL/SQL也是一种程序语言,叫做过程化SQL语言(Procedural Language/SQL)。PL/SQL是Oracle数据库对SQL语句的扩展。在普通SQL语句的使用上增加了编程语言的特点,所以PL/SQL就 是把数据操作和查询语句组织在PL/SQL代码的过程性单元中,通过逻辑判断、循环等操作实现复杂的功能或者计算的程序语言。

继续阅读

Linux下彻底删除Oracle

1. 用 oracle 用户登录

如果要再次安装, 最好先做一些备份工作。
包括用户的登录脚本,数据库自动启动关闭的脚本,和 Listener 自动启动的脚本。
要是有可能连创建数据库的脚本也保存下来

2. 使用 SQL*PLUS 停止数据库
[oracle@ora920 oracle]$ sqlplus /nolog
SQL> connect / as sysdba
SQL> shutdown
SQL> exit

继续阅读

RAC下修改oracle归档模式

oracle的所有默认配置都是不好的,要不然服务就卖不了钱了··

数据库默认安装以后,所有都是非归档模式,这样对于数据库的安全性而言,是很不好的,所以必须将数据库修改为归档模式,单实例数据库的修改是比较简单,而rac的话,还是有点点复杂,

继续阅读

TRUNCATE和DELETE区别

1、TRUNCATE在各种表上无论是大的还是小的都非常快。如果有ROLLBACK命令DELETE将被撤销,而TRUNCATE则不会被撤销。
2、TRUNCATE是一个DDL语言,向其他所有的DDL语言一样,他将被隐式提交,不能对TRUNCATE使用ROLLBACK命令。
3、TRUNCATE将重新设置高水平线和所有的索引。在对整个表和索引进行完全浏览时,经过TRUNCATE操作后的表比DELETE操作后的表要快得多。
4、TRUNCATE不能触发任何DELETE触发器。
5、不能授予任何人清空他人的表的权限。
6、当表被清空后表和表的索引讲重新设置成初始大小,而delete则不能。
7、不能清空父表。 TRUNCATE TABLE (schema)table_name DROP(REUSE) STORAGE 在默认是 DROP STORAGE 当使用DROP STORAGE时将缩短表和表索引,将表收缩到最小范围,并重新设置NEXT参数。REUSE STORAGE不会缩短表或者调整NEXT参数在特殊情况下使用 REUSE ST

DELETE 语句执行删除的过程是每次从表中删除一行,并且同时将该行的的删除操作作为事务记录在日志中保存以便进行进行回滚操作。
TRUNCATE TABLE 则一次性地从表中删除所有的数据页并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。

sql2000常见问题

////////////////////////////////安装问题//////////////////////////

Win2k      装不上      SQL      Server      2000      问题很常见.
//          (1)配置服务器时中断.
//          (2)注册      ActiveX      时中断.
//          (3)显示到100%的时候中断.
当然重新安装      Windows      2000      完全可以安装      SQL      Server      2000.

安全起见:
1>先备份您的注册表.
2>备份您的数据[进不了SQL      Server      2000,可以备份      Program
Files\Microsoft      SQL  &nbsp103f;   Server\MSSQL\Data      文件夹的文件.]

您必须知道:
Windows      2000        Server可以安装SQL      Server      2000的任何版本.
Windows      2000        Professional只能安装SQL      Server      2000的个人版本.(通过一些办法也可以安装其他版本)

有两种办法:
1:先卸载您的      SQL      Server      2000,必要的时候删除      Program
Files\Microsoft      SQL      Server      文件夹.
2:放入      SQL      Server      2000      光盘.
3:在”开始”–“运行”键入      “F:\x86\setup.exe      k=dbg”      (F是光盘)
[此命令的意思单步运行安装      SQL      Server      2000]
4:98%安装不成功,没有任何的提示.可能是:
(1)配置服务器时中断.
(2)注册      ActiveX      时中断.
(3)显示到100%的时候中断.

这样一来,您只能使用下面的办法了!否则,您只有      FORMAT了!
1      打开注册表
在”开始”–“运行”键入      “regedit”
2      按下列顺序点击打开
+      HKEY_LOCAL_MACHINE
+      SOFTWART
+      Microsoft
+      Windows
+      CurrentVersion
&103fnbsp;                                       +      Setup
+      ExceptionComponents
3      将      ExceptionComponents      下面的文件夹全部删除!
如      {60BFF50D-FB2C-4498-A577-C9548C390BB9}
{60BFF50D-FB2C-4498-A577-C9548C390BB9}
{60BFF50D-FB2C-4498-A577-C9548C390BB9}
{60BFF50D-FB2C-4498-A577-C9548C390BB9}
…….

4      重新启动:
5      重新安装      SQL      Server      2000

————————————————————————————–
如果问题依旧,试试先修复操作系统.

命令提示符下执行:
sfc      /scannow

最后的方法:换Windows 2000 安装盘 和SQL Server2000安装盘

有时候问题的原因很奇怪,有人曾更换了一个电源就解决了问题。

1 先卸载您的 SQL Server 2000,必要的时候删除 Program FilesMicrosoft SQL Server 文件夹

2 打开注册表 在”开始”–“运行”键入 “regedit”

3 按下列顺序点击打开 + HKEY_LOCAL_MACHINE + SOFTWART + Microsoft + Windows + CurrentVersion + Setup + ExceptionComponents

4 将 ExceptionComponents 下面的文件夹全部删除! 如 {60BFF50D-FB-4498-A577-C390BB9} {60BFF50D-FB-4498-A577-C390BB9} {60BFF50D-FB-4498-A577-C390BB9} {60BFF50D-FB-4498-A577-C390BB9}

6 重新启动: 7 重新安装 SQL Server 2000

其他方法: — SQL Server 2000安装错误“安装配置服务器失败”解决方法

研究了两天的心得。 安装SQL Server 2000时,在安装后面如果出现“安装配置服务器失败”错误,并且安装终止时,可能引起的原因如下: 当您在安装了证书服务器的计算机上安装 SQL Server 2000 时将出现一个错误消息。如果证书服务器安装在运行 Microsoft Windows 2000/2003 的计算机103f上,且证书颁发机构 (CA) 名称与机器主机名相同或以机器主机名开头,那么您的 SQL Server 2000 安装程序将失败,您会收到下面的错误消息: 安装程序配置服务器失败。参考服务器错误日志和 C:WINDOWSsqlstp.log 了解更多信息。

此问题最早是在 SQL Server 2000 Service Pack 1 中纠正的。 有关其他信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章: 302409 FIX:Unable to Connect to SQL Server 2000 When Certificate Authority Name Is the Same As the Host Name of the Windows 2000 Computer 解决方法:删除“证书服务”。

(1) 打开“控制面板”->“添加或删除程序”->“添加/删除Windows组件”

(2) 在打开的窗口中,把“证书服务”前面的勾去掉,如下图所示:

(3) 点击下一步,直至完成。

(4)重新安装SQL Server 2000。

问:安装MSDE时出现:“配置服务器失败,请参考服务器错误日志和安装错误日志,以了解更多信息”

答:此问题可能是由于计算机系统驱动器上还保留着以前的用户数据,安装程序不会覆盖以前的用户数据,因而导致配置服务器失败。

可以尝试用下面的方法来解决此问题: 删除 [系统驱动器号]:Program FilesMicrosoft SQL ServerMSSQL 文件夹

另外,安装时还要注意:

1、用有系统管理员权限的用户来执行安装操作;

2、建议安装前先退出其他应用程序,和暂停使用防病毒软件和防火墙; 如果机器上安装过SQL Server 清理操作系统注册表下如下路径的残存文件: HKEY_CURRENT_USERSoftwareMicrosoftMSSQLServer HKEY_LOCAL_MACHINESOFTWAREMicrosoftMSSQLServer 并且删除磁盘中原来安装路径下的残存文件

//////////////////////////////////////卸载//////////////////////////////////////////////////////////

 

如何卸载SQLServer2000

通过正常方法无法卸载SQLServer2000时,可以使用下面的方法:
(1)在计算机windows的“开始-运行”弹出窗口内录入“regedit.exe”,在出现的〔注册表编辑器〕里删除以下选项。     # HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer
# HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQLServer
# HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MSSQLServer
# HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\SQLSERVERAGENT
# HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MSSQLServerADHelper
(2)手工删除SQL Server 2000默认安装目录C:\Program Files\Microsoft SQL Server。
(3)重新启动计算机。重装SQL或者MSDE的注意事项

重新安装SQL或者MSDE必须注意以下几个方面的要点。
(1)计算机是否按照上面所介绍的已经完整的删除了SQL旧软件和它的注册表信息。
(2)SQL不能安装在除win 2000以外的系统上,而如果要安装服务器的SQL,那么计算机必须首先安装了win2000Server或者Win2000 Advance Server,这样的系统基础才可以安装SQL Server 2000作为服务器端数据库。
(3)MSDE可以在任何windows系统内安装作为单机版数据库环境,但如果计算机已经存在SQL或者MSDE系统,重新安装就会出错,必须完整删除已有的SQL或者MSDE系统才能重装。
(4)重装完毕必须重启计算机。解决sql2000挂起无法安装的问题

解决sql2000挂起无法安装的问题
出现“以前的某个程序安装已在安装计算机上创建挂起的文件操作。运行安装程序之前必须重新启动计算机”错误。
步骤是:
1)添加/删除程序中彻底删除sql server。
2)将没有删除的sql server目录也删除掉。
3)打开注册表编辑器,在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager
中找到PendingFileRenameOperations项目,并删除它。这样就可以清除安装暂挂项目。
4)删除注册表中跟sql server相关的键。
一般只需要执行第三步就能解决问题了SQL Server 2000端口连接不上

SQL    Server连接中的三个最常见错误:

一.”SQL    Server    不存在或访问被拒绝”

这个是最复杂的,错误发生的原因比较多,需要检查的方面也比较多.

一般说来,有以下几种可能性:

1,SQL    Server名称或IP地址拼写有误
2,服务器端网络配置有误
3,客户端网络配置有误

要解决这个问题,我们一般要遵循以下的步骤来一步步找出导致错误的原因.

=============    首先,检查网络物理连接    =============
ping    <服务器IP地址/服务器名称>

如果    ping    <服务器IP地址>    不成功,说明物理连接有问题,这时候要检查硬件设备,如网卡,HUB,路由器等.
还有一种可能是由于客户端和服务器之间安装有防火墙软件造成的,比如    ISA    Server.防火墙软件可能会屏蔽对    ping,telnet    等的响应
因此在检查连接问题的时候,我们要先把防火墙软件暂时关闭,或者打开所有被封闭的端口.

如果ping    <服务器IP地址>    成功而,ping    <服务器名称>    失败
则说明名字解析有问题,这时候要检查    DNS    服务是否正常.
有时候客户端和服务器不在同一个局域网里面,这时候很可能无法直接使用服务器名称来标识该服务器,这时候我们可以使用HOSTS文件来进行名字解析,
具体的方法是:

1.使用记事本打开HOSTS文件(一般情况下位于C:\WINNT\system32\drivers\etc).
添加一条IP地址与服务器名称的对应记录,如:
172.168.10.24    myserver

2.或在    SQL    Server    的客户端网络实用工具里面进行配置,后面会有详细说明.

=============    其次,使用    telnet    命令检查SQL    Server服务器工作状态    =============
telnet103f    <服务器IP地址>    1433

如果命令执行成功,可以看到屏幕一闪之后光标在左上角不停闪动,这说明    SQL    Server    服务器工作正常,并且正在监听1433端口的    TCP/IP    连接
如果命令返回”无法打开连接”的错误信息,则说明服务器端没有启动    SQL    Server    服务,
也可能服务器端没启用    TCP/IP    协议,或者服务器端没有在    SQL    Server    默认的端口1433上监听.

=============接着,我们要到服务器上检查服务器端的网络配置,检查是否启用了命名管道.是否启用了    TCP/IP    协议等等    =============
可以利用    SQL    Server    自带的服务器网络使用工具来进行检查.

点击:程序    —    Microsoft    SQL    Server    —    服务器网络使用工具

打开该工具后,在”常规”中可以看到服务器启用了哪些协议.
一般而言,我们启用命名管道以及    TCP/IP    协议.
点中    TCP/IP    协议,选择”属性”,我们可以来检查    SQK    Server    服务默认端口的设置
一般而言,我们使用    SQL    Server    默认的1433端口.如果选中”隐藏服务器”,则意味着客户端无法通过枚举服务器来看到这台服务器,起到了保护的作用,但不影响连接.

=============    接下来我们要到客户端检查客户端的网络配置    =============
我们同样可以利用    SQL    Server    自带的客户端网络使用工具来进行检查,
所不同的是这次是在客户端来运行这个工具.

点击:程序    —    Microsoft    SQL    Server    —    客户端网络使用工具

打开该工具后,在”常规”项中,可以看到客户端启用了哪些协议.
一般而言,我们同样需要启用命名管道以及    TCP/IP    协议.
点击    TCP/IP    协议,选择”属性”,可以检查客户端默认连接端口的设置,该端口必须与服务器一致.

单击”别名”选项卡,还可以为服务器配置别名.服务器的别名是用来连接的名称,
连接参数中的服务器是真正的服务器名称,两者可以相同或不同.别名的设置与使用HOSTS文件有相似之处.

通过以上几个方面的检查,基本上可以排除第一种错误.  &103fnbsp;

—————————————————————————–

二.”无法连接到服务器,用户xxx登陆失败”

该错误产生的原因是由于SQL    Server使用了”仅    Windows”的身份验证方式,
因此用户无法使用SQL    Server的登录帐户(如    sa    )进行连接.解决方法如下所示:

1.在服务器端使用企业管理器,并且选择”使用    Windows    身份验证”连接上    SQL    Server
2.展开”SQL    Server组”,鼠标右键点击SQL    Server服务器的名称,选择”属性”,再选择”安全性”选项卡
3.在”身份验证”下,选择”SQL    Server和    Windows    “.
4.重新启动SQL    Server服务.

在以上解决方法中,如果在第    1    步中使用”使用    Windows    身份验证”连接    SQL    Server    失败,
那就通过修改注册表来解决此问题:

1.点击”开始”-“运行”,输入regedit,回车进入注册表编辑器
2.依次展开注册表项,浏览到以下注册表键:
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer]
3.在屏幕右方找到名称”LoginMode”,双击编辑双字节值
4.将原值从1改为2,点击”确定”
5.关闭注册表编辑器
6.重新启动SQL    Server服务.

此时,用户可以成功地使用sa在企业管理器中新建SQL    Server注册,
但是仍然无法使用Windows身份验证模式来连接SQL    Server.
这是因为在    SQL    Server    中有两个缺省的登录帐户:
BUILTIN\Administrators
<机器名>\Administrator    被删除.
要恢复这两个帐户,可以使用以下的方法:

1.打开企业管理器,展开服务器组,然后展开服务器
2.展开”安全性”,右击”登录”,然后单击”新建登录”
3.在”名称”框中,输入    BUILTIN\Administrators
4.在”服务器角色”选项卡中,选择”System    Administrators”
5.点击”确定”退出
6.使用同样方法添加    <机器名>\Administrator    登录.

说明:

以下注册表键:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLSer103fver\LoginMode
的值决定了SQL    Server将采取何种身份验证模式.
1.表示使用”Windows    身份验证”模式
2.表示使用混合模式(Windows    身份验证和    SQL    Server    身份验证).

—————————————————————————–

三.提示连接超时

如果遇到第三个错误,一般而言表示客户端已经找到了这台服务器,并且可以进行连接,
不过是由于连接的时间大于允许的时间而导致出错.
这种情况一般会发生在当用户在Internet上运行企业管理器来注册另外一台同样在Internet上的服务器,
并且是慢速连接时,有可能会导致以上的超时错误.有些情况下,由于局域网的网络问题,也会导致这样的错误.

要解决这样的错误,可以修改客户端的连接超时设置.
默认情况下,通过企业管理器注册另外一台SQL    Server的超时设置是    4    秒,
而查询分析器是    15    秒(这也是为什么在企业管理器里发生错误的可能性比较大的原因).

具体步骤为:
企业管理器中的设置:
1.在企业管理器中,选择菜单上的”工具”,再选择”选项”
2.在弹出的”SQL    Server企业管理器属性”窗口中,点击”高级”选项卡
3.在”连接设置”下的”登录超时(秒)”右边的框中输入一个比较大的数字,如    20.

查询分析器中的设置:
工具    —    选项    —    连接    —    将登录超时设置为一个较大的数字

===================================================================

总结:

1.先保证ping通(有防火墙的先关闭防火墙)
2.在命令提示符下执行:telnet    <服务器ip地址>    1433    不会报错
3.连接时使用用ip连接企业管理器
4.如果不行
SQL    Server服务器–开始–程序–Microsoft    SQL    Server
–服务器网络实用工具
–启用    WinSock代理
–代理地址:(sqlserver服务器IP)
–代理端口–1433
—确定

5.如果还不行,在客户端装个SQL    Server客户端配置一下:
开始–程序–Microsoft    SQL    Server–客户端网络实