数据库相关知识积累(sqlserveroraclemysql

1. sqlserver :断开所有连接: (还原数据库)

1.数据库  分离

2.

USE master

GO

ALTER DATABASE [GPOSDB] SET SINGLE_USER WITH ROLLBACK IMMEDIATE

GO

--查看是否还有用户连接

SELECT * FROM sys.[sysprocesses] WHERE DB_NAME([dbid])='gposdb'

GO

ALTER DATABASE [GPOSDB] SET MULTI_USER

GO

2.SQL server:除非另外还指定了 TOP、OFFSET 或 FOR XML,否则,ORDER BY 子句在视图、内联函数、派生表、子查询和公用表表达式中无效。(SQLSERVER数据库)

原因:默认情况下,如果在子查询,函数,视图中尝试使用order by,就遇到这种错误,原因是针对一个表的select其实并不是返回一个表,而是一个游标(不知道Oracle数据库是不是相同情况)

3. sqlserver插入单引号:在sqlserver中用两个单引号就代表一个单引号

insert into tb(field) values('a''bc');

mysql中用\'

insert into tb(field) values('a\'bc');

4. sqlser替换某字段某字符串:

update sysmailtemplate set body = REPLACE(convert(varchar(8000),body),'http://www.xxx.com','javascript:void(window.open("http://www.xxx.com", "newwindow", "width=1050,height=650,scrollbars=yes"))')

5. oracle小数转字符串

1.保留小数点前后的0

to_char('120.50','fm99990.009'):120.500 保留三位小数,fm表示去掉因为9占位而多出来的空格

to_char('0.25','fm99990.09'):0.25 保留两位小数

2.如果是整数,上述方法会在后面多一个小数点

to_char('120','fm99990.09'):120.

用trim()去掉最后的小数点:trim('.' from to_char('120','fm99990.09'))

或者to_char('120','fm99990.00')

6. sqlserver数据库create表:select * into tablenew from tableold

与Oracle不同:create table tablenew as select * from tableold

7. mysql创建索引:

两种方式,一种alter table,一种create

1.alter table

ALTER TABLE table_name ADD INDEX index_name (column_list)

ALTER TABLE table_name ADD UNIQUE (column_list)

ALTER TABLE table_name ADD PRIMARY KEY (column_list)

2.create --create 不能创建primary key 索引

CREATE INDEX index_name ON table_name (column_list)

CREATE UNIQUE INDEX index_name ON table_name (column_list)

删除索引:

可利用ALTER TABLE或DROP INDEX语句来删除索引。类似于CREATE INDEX语句,DROP INDEX可以在ALTER TABLE内部作为一条语句处理,语法如下:

DROP INDEX index_name ON talbe_name

ALTER TABLE table_name DROP INDEX index_name

ALTER TABLE table_name DROP PRIMARY KEY

8.sqlserver,row_number不排序方法:select a.*,row_number() over (order by (select 0)) as rn from SYSUSER a

9.SQL server创建索引:

create [unique] [clustered] [nonclustered] index index_name

on {tabel/view} (column[dese/asc][....n])

create unique clustered index index_name

on kshouse (Id)

10. sqlserver建表(主键):

CREATE TABLE [dbo].[house](

[Id] [nvarchar](36) NOT NULL,

[CreateDate] [datetime] NULL,

[HouseCode] [nvarchar](50) NULL,

[ImgUri] [nvarchar](200) NULL,

[Display] [nvarchar](1000) NULL,

[Yezhushuo] [nvarchar](50) NULL,

[HouseName] [nvarchar](200) NULL,

[HouseDescribe] [nvarchar](200) NULL,

[Area] [nvarchar](200) NULL,

[HouseType] [nvarchar](100) NULL,

[PostMessage] [nvarchar](200) NULL,

[TotalPrice] [nvarchar](50) NULL,

[UnitPrice] [nvarchar](50) NULL,

CONSTRAINT [PK_house] PRIMARY KEY CLUSTERED

(

[Id] ASC

)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY])

11.sqlser连接远程数据库:

--连接远程数据库 1

exec sp_addlinkedserver 'zc','','SQLOLEDB','129.204.88.98'

exec sp_addlinkedsrvlogin 'zc','false',null,'sola','Z342516106c'

insert into zc.[Crawler].[dbo].[Orders](Customer,OrderDate) select Customer,OrderDate from Orders

--以后不再使用时删除链接服务器

exec sp_dropserver 'zc', 'droplogins'

12. sqlserver相关子查询Exists

相关子查询:子查询的查询条件依赖外层查询 ,带Exists的查询就是相关子查询。

Exists 子查询语句不关心查询结果具体是啥,只关心结果集是否为空,若结果集为空则返回false,若不为空则返回true(Not Exists正好相反);

SELECT 姓名

FROM 学生表

WHERE EXISTS

(

SELECT *

FROM 选课表

WHERE 学生表.学号 = 选课表.学号 AND 课程号 = 'C1'

);

相关子查询执行过程:先在外层查询中取“学生表”的第一行记录,用该记录的相关的属性值(在内层WHERE子句中给定的)处理内层查询,若外层的WHERE子句返回“TRUE”值(内层where有数据),则这条记录放入结果表中。然后再取下一行记录;重复上述过程直到外层表的记录全部遍历一次为止。

13.sqlser:游标更新列

declare

@id as nvarchar(36),

@Year as nvarchar(10),

@Month as nvarchar(10),

@Day as nvarchar(10)

declare cursor_ymd cursor fast_forward for

select id,

datename(year,createdate) as Year,

convert(int,datename(month,createdate)) as Month,

datename(day,createdate) as Day

from house;

open cursor_ymd;

fetch next from cursor_ymd into @id,@Year,@Month,@Day while @@FETCH_STATUS = 0

begin

update house set Year = @Year,Month = @Month, Day = @Day where id = @id;

fetch next from cursor_ymd into @id,@Year,@Month,@Day;

end

close cursor_ymd;

deallocate cursor_ymd;

14. sqlserve返回两个日期之间的时间:DATEDIFF(datepart,startdate,enddate):select datediff(day,getdate(),getdate() + 1) -- 1

datepart取值:day、month、year、week

15.pl/sql安装:

1.首先安装oracle客户端

2.打开plsql,第一次进先点cancel,然后tool->preference

3.重启,输入用户名密码,看到database为空不要着急,也不要配环境变量,直接写数据库地址、端口号、服务名即可:172.20.70.112:1521/feiliextsrv

16. sqlserver 数据库,区分大小写查询

select * from WorkflowInstance where xaml COLLATE Chinese_PRC_CS_AS like '%Car批准%'

17. oracle字符集,客户端与服务端字符集不一致,常常导致查询出错或中文乱码

select userenv('language') from dual;--客户端

select * from NLS_DATABASE_PARAMETERS;--服务端字符集

SELECT * FROM V$NLS_PARAMETERS;--客户端字符集

--修改客户端字符集要改环境变量,不知道改注册表改的是哪里的字符集,注册表与环境变量不一致,好像采用环境变量的配置

18.sqlplus使用:sqlplus projtest/projtest@127.0.0.1:1521/orcl

19.sqlserver类似宏定义的东西:

use Oncontrol_Test;--加上这个,说明查的是Oncontrol_Test里面的表(数据库名或用户名),这是一个更改数据库的操作,改完后,所有操作都执行在当前库中

select * from task;

20.sqlserver 查询表属性:

--1.

select

syscolumns.name as "列名",

case when syscolumns.isnullable = '0' then '否' else '是' end as "可否为空",

systypes.name as "数据类型",

syscolumns.[length] as "类型长度",

case when ISNULL(sys.identity_columns.is_identity,0) = '0' then '否' else '是' end as "是否主键",

ISNULL(sys.extended_properties.value,'') as "备注"

from sysobjects

join syscolumns on sysobjects.id = syscolumns.id

join systypes on syscolumns.xusertype = systypes.xusertype

left join sys.identity_columns

on sys.identity_columns.object_id = syscolumns.id and sys.identity_columns.column_id = syscolumns.colid

left join sys.extended_properties on sys.extended_properties.major_id = syscolumns.id

and sys.extended_properties.minor_id = syscolumns.colid

where sysobjects.name = 'PlanFlows'

--2.

SELECT  CASE WHEN col.colorder = 1 THEN obj.name

ELSE ''

END AS 表名,

col.colorder AS 序号 ,

col.name AS 列名 ,

ISNULL(ep.[value], '') AS 列说明 ,

t.name AS 数据类型 ,

col.length AS 长度 ,

ISNULL(COLUMNPROPERTY(col.id, col.name, 'Scale'), 0) AS 小数位数 ,

CASE WHEN COLUMNPROPERTY(col.id, col.name, 'IsIdentity') = 1 THEN '1'

ELSE ''

END AS 标识 ,

CASE WHEN EXISTS ( SELECT   1

FROM     dbo.sysindexes si

INNER JOIN dbo.sysindexkeys sik ON si.id = sik.id

AND si.indid = sik.indid

INNER JOIN dbo.syscolumns sc ON sc.id = sik.id

AND sc.colid = sik.colid

INNER JOIN dbo.sysobjects so ON so.name = si.name

AND so.xtype = 'PK'

WHERE    sc.id = col.id

AND sc.colid = col.colid ) THEN '1'

ELSE ''

END AS 主键 ,

CASE WHEN col.isnullable = 1 THEN '1'

ELSE ''

END AS 允许空 ,

ISNULL(comm.text, '') AS 默认值

FROM    dbo.syscolumns col

LEFT  JOIN dbo.systypes t ON col.xtype = t.xusertype

inner JOIN dbo.sysobjects obj ON col.id = obj.id

AND obj.xtype = 'U'

AND obj.status >= 0

LEFT  JOIN dbo.syscomments comm ON col.cdefault = comm.id

LEFT  JOIN sys.extended_properties ep ON col.id = ep.major_id

AND col.colid = ep.minor_id

AND ep.name = 'MS_Description'

LEFT  JOIN sys.extended_properties epTwo ON obj.id = epTwo.major_id

AND epTwo.minor_id = 0

AND epTwo.name = 'MS_Description'

WHERE   obj.name = 'SYSGROUPPERMISSION'--表名

ORDER BY col.colorder ;

21.sqlserver触发器与Nhibernate冲突:

--创建触发器

--与NHibernate冲突,添加set nocount

create trigger tri_task on TASK

after update

as

declare @ID varchar(50)

if update(Status)

begin

SET NOCOUNT ON

select @ID = ID from inserted;

update DATASYNC set MODIFYTIME = GETDATE(),ISUPDATE = '1' where DATAID = @ID;

SET NOCOUNT OFF

End

22.获取字符串长度

sqlserver:len(colname)、datalength(colname)

oracle:length(colname)

23.ORACLE数据库创建用户:
-- 创建表空间
CREATE TABLESPACE CHAOSHIGW
LOGGING
DATAFILE 'G:\app\oradata\orcl\chaoshigw.DBF' -- ORACLE安装目录
SIZE 100M
AUTOEXTEND ON
NEXT 30M MAXSIZE UNLIMITED
EXTENT MANAGEMENT LOCAL;
-- 创建临时表空间
CREATE TEMPORARY TABLESPACE CHAOSHIGW_TEMP
TEMPFILE 'G:\app\oradata\orcl\chaoshigw_temp.DBF'
SIZE 32M
AUTOEXTEND ON
NEXT 32M MAXSIZE UNLIMITED
EXTENT MANAGEMENT LOCAL;
-- 创建用户
CREATE USER chaoshigw IDENTIFIED BY chaoshigw123
ACCOUNT UNLOCK
DEFAULT TABLESPACE CHAOSHIGW
TEMPORARY TABLESPACE CHAOSHIGW_TEMP;
-- 授权
GRANT CONNECT,RESOURCE TO chaoshigw;
GRANT DBA TO chaoshigw;

24. oracle远程连接数据库,实现跨库查询(数据迁移),创建dblink

create database link database_link_test --数据库别名
connect to chaoshigw identified by "database!pass" -- 用户名/密码
using '127.0.0.1:1521/orcl';

--不含lob类型字段,可以直接查询
select * from goods@database_link_test
--含lob类型字段的表,查询报错ora-22992,采取临时表的方式
create table temptable as select * from webpart@database_link_test--建临时表
insert into webpart select * from temptable

--断开dblink

drop database link database_link_test

数据库相关知识积累(sqlserver、oracle、mysql)的更多相关文章

  1. ABP框架使用Mysql数据库,以及基于SQLServer创建Mysql数据库的架构和数据

    ABP默认的数据库是SQLServer,不过ABP框架底层是EF框架,因此也是很容易支持其他类型的数据库的,本篇随笔介绍在ABP框架使用Mysql数据库,以及基于SQLServer创建MySql数据库 ...

  2. SQLServer Oracle MySQL的区别

    table tr:nth-child(odd){ background: #FFFFCC; font-size: 18px; } table tr:nth-child(even){ backgroun ...

  3. mysql数据库相关知识

    什么是数据库?                数据库(Database)是按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库.(来自:百度) 什么是sql? 结构化查询语言(Struct ...

  4. atitit.sql server2008导出导入数据库大的表格文件... oracle mysql

    atitit.sql server2008导出导入数据库大的表格文件... 1. 超过80M的文件是不能在查询分析器中执行的 1 2. Oracle ,mysql大的文件导入 1 2.1. 使用sql ...

  5. MYSQL数据库相关知识合集

    1  MYSQL取得某一范围随机数: 关键词:RAND() [产生0~1之间的随机数] mysql> SELECT RAND( ), RAND( ), RAND( ); +----------- ...

  6. 随笔编号-06 MYSQL数据库相关知识合集

    1  MYSQL取得某一范围随机数: 关键词:RAND() [产生0~1之间的随机数] mysql> SELECT RAND( ), RAND( ), RAND( ); +----------- ...

  7. sqlserver,oracle,mysql等的driver驱动,url怎么写

    oracle driver="oracle.jdbc.driver.OracleDriver" url="jdbc:oracle:thin:@localhost:1521 ...

  8. SqlServer,Oracle,Mysql 获取指定行数

    --sqlserver * FROM dbo.T_TASK --oracle --mysql ,

  9. 添加数据库的Maven依赖(SqlServer,Oracle)

    oracle: 1.在Oracle官网下载ojdbc的jar包 例:ojdbc7.jar,版本是12.1.0.2,存储地址/home/peng/下载 2.dos中进入存储地址执行如下命令行(注意各项对 ...

随机推荐

  1. Dockerfile优化

    总结: 1.编写.dockerignore文件 2.容器只运行单个应用 3.将多个RUN指令合并为一个 4.基础镜像的标签不要用latest 5.每个RUN指令后删除多余文件 6.选择合适的基础镜像( ...

  2. Linux系统学习 十一、DHCP服务器—相关文件、配置文件、服务器配置

    2.DHCP服务器相关文件 安装SHCP服务器 yum install dhcp 对应的端口 端口号: ipv4 udp67.udp68(不推荐改端口) ipv6 udp546.udp547(暂时还没 ...

  3. 07-Django视图进阶

    1.调试模式 Django项目下的settings.py 默认是DEBUG=True,开发的时候一般要开启调试模式,当项目完成发布必须要改成False,否则会暴露网站的配置信息,修改以下两行: # D ...

  4. 六、接上一个博客-ITK例子运行结果

    一.程序介绍 该程序的主要思路如下: 二.程序参数 1-程序自己创建三维图像的时候 我自己计算得到的参数如下: 三维图像参数:  旋转参数: 光线投射法参数: 当我们输入参数:  -v 得到程序的输出 ...

  5. 磕磕绊绊中,使用Git工具完成代码上传

    1.安装Git工具 1)下载并安装Git工具:Git下载地址 安装完成之后,在桌面空白处点击右键,会出现以下选项: 2.初始化环境 1) 在一文件夹中,点击右键,选择上图中的Git Bash Here ...

  6. 在python操作数据库中游标的使用方法

    cursor就是一个Cursor对象,这个cursor是一个实现了迭代器(def__iter__())和生成器(yield)的MySQLdb对象,这个时候cursor中还没有数据,只有等到fetcho ...

  7. js中scroll滚动相关

    js中scroll滚动相关 scroll,滚动,一般讨论的是网页整体与浏览器之间的关系. 一.元素相关 属性/方法 解释 element.scrollHeight 返回元素的整体高度. element ...

  8. 利用socket传递图片

    package com.company.s3; import java.io.File; import java.io.FileOutputStream; import java.io.InputSt ...

  9. SAP 销售订单交货对成本中心记账

    销售订单发货不计入主营业务成本,而是直接接入费用科目,与成本中心挂钩的业务经常发生.不少公司只是简单地处理交货,计入主营业务成本,然后财务再手工将成本归结到相关的成本中心.其实SAP系统是支持销售订单 ...

  10. c# 获取sqlserver 运行脚本的print消息的方法分享

    转自:http://www.maomao365.com/?p=6923  摘要: 在sql脚本的编写中,我们经常使用sql脚本print消息,作为输出测试, 通过获取print消息,我们可以快速获取程 ...