怎么判断sql数据库是不是存在,存在删除
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么判断sql数据库是不是存在,存在删除相关的知识,希望对你有一定的参考价值。
判断数据库,如果存在则删除:
IF (EXISTS(SELECT * FROM master.dbo.sysdatabases WHERE dbid=db_ID('dbname')))
DROP DATABASE dbname
如果提示:删除数据库时提示数据库正在被使用,无法删除(Cannot drop database databasename because it is currently in use),使用:
IF (EXISTS(SELECT * FROM master.dbo.sysdatabases WHERE dbid=db_ID('dbname')))
BEGIN
USE master
ALTER DATABASE dbname
SET single_user
WITH ROLLBACK IMMEDIATE
DROP DATABASE dbname
END
扩展资料
判断储存过程,如果存在则删除
IF (EXISTS(SELECT * FROM sysobjects WHERE name='procedurename' AND type='P'))
DROP PROCEDURE procedurename
判断触发器,如果存在则删除
IF (EXISTS(SELECT * FROM sysobjects WHERE id=object_id(N'[dbo].[triggername]') AND OBJECTPROPERTY(id, N'IsTrigger') = 1))
DROP TRIGGER triggername
判断用户函数是否存在,如果存在则删除
此处type有两种: 'TF'- Table-Value Function 表值函数 'FN'- Scalar-Value Function 标量值函数
IF (EXISTS(SELECT * FROM sysobjects WHERE id=object_id(N'[dbo].[userfunction]') AND (type='FN' OR type='TF')))
DROP FUNCTION userfunction
参考技术A 如何判断数据库是否存在 执行下列的SQL,获得一张表,根据表的行数来判断。select * from master..sysdatabases where name=N'所查询的数据库名'
if exists(select * from master.dbo.sysdatabases where name = 'yexinwinners')
begin
drop database yexinwinners
print 'yexinwinners己存在,己被删除'
end
else
begin
create database yexinwinners
on primary
(
name = yexinwinners_mdf,
filename = 'c:\yexinwinners.mdf',
size = 10mb,
maxsize = 50mb,
filegrowth = 25%
)
log on
(
name = yexinwinners_ldf,
filename = 'c:\yexinwinners.ldf',
size = 10mb,
maxsize = 50mb,
filegrowth = 25%
)
print 'yexinwinners 数据库创建成功'
end本回答被提问者采纳
SQL SERVER 建表时先判断表有没有存在
我是用查询分析器建立表的,
每次建立表,如果表存在,就要先删除,很麻烦
能不能这样:
建表的时候,先判断表是否存在,如果存在,则不建表,如果不存在,就建立表
或者
建表的时候,先判断表是否存在,如果存在,删除表再建立表,如果不存在,就建立表
请问SQL SERVER 代码怎么写啊?
高手,如果强的话,能不能把
ORACLE 和 MYSQL 的相同代码也写写啊?
谢谢啊
谈论用户名
您写的代码我看不懂啊,这个 USE GO 是固定搭配吗?
能不能给个更简单的?
1、打开数据库选中要创建表的数据库,在数据库中打开表,然后点新建,创建表,就会出现一个建表窗口。
2、在这里可以输入设置相关表的结构类型,在新窗口输入数据类型字段名称和大小。
3、每个表为了数据的唯一,提高查询性能都需要创建一个主键,这个字段没什么意义。只是起个标识。
4、主键一般可以设为数字或字符串,在这里设主键递增为数字型,字符串需要单独处理。
5、主键和字段类型创建好后,就可以保存了。直接点保存就可以了。
6、通过查询分析器,用语句建表。打表查询器输入语句。
参考技术ASQL SERVER 建表时先判断表存在情况如下:
在sqlserver中,创建表之前判断表是否存在,如果存在则删除已有表Sql代码
----SQL-Server
if exists (select 1 from sysobjects where id = object_id('EMP') and type = 'U')
drop table S_Evaluate go --CREATE Table: EMP create table EMP( Id numeric
identity, -- 评估ID Conclusion text null --结论
constraint PK_S_EMP primary key nonclustered(Id) )
go ORACLE 数据库
但是在oracle中却没有。如果直接使用drop table那么如果表不存在会报错,导致后续语句无法运行。因此可以通过一个存储过来来进行判断。
主要是查询all_tables表的TABLE_NAME和OWNER,如果表存在,则执行execute immediate 'drop table TABLE_NAME';
Sql代码
--判断表是否存在,如果存在则删除
declare
num number;
begin select count(1) into num from all_tables where TABLE_NAME = 'EMP' and
OWNER='SCOTT';
if num=1 then
execute immediate 'drop table EMP';
end if; end; / --创建表
CREATE TABLE EMP
(EMPNO NUMBER(4) NOT NULL,
ENAME VARCHAR2(10),
JOB VARCHAR2(9),
MGR NUMBER(4),
HIREDATE DATE,
SAL NUMBER(7, 2),
COMM NUMBER(7, 2),
DEPTNO NUMBER(2));
删除表的如下:
Sql代码
CREATE PROCEDURE ExistsTest(IN TableName varchar(50),OUT iReturn int)
LANGUAGE SQL
P1: BEGIN
DECLARE stmt VARCHAR(200);
IF EXISTS (select * from sysibm.systables where TID <> 0 and name = TableName ) THEN
set stmt ='drop table '|| TableName;
PREPARE s1 FROM stmt;
EXECUTE s1;
set iReturn =0;
else
set iReturn =-1;
END IF;
END P1@
END P1后面的@根据所用编辑工具的不同,默认的结束也不一样。测试了一下QUEST CENTRAL FOR DB2,默认是分号,如果想用@自己修改工具的配置吧
由于DB2不像sqlserver那样把所有对象组织到一个sysobjects里,所以想要实现不同的功能就需要修改这个存储过程,
如:
syscat.procedures 存储过程
syscat.tables 表
sysibm.tables 表
syscat.views 视图
sysibm.views 视图
sysibm.tables的表里面的信息比syscat.tables的少,或者说IBM认为你想知道的信息在sysibm.tables里面已经都可以知道了,这个应该是给用户使用的。syscat.tables应该是给系统使用的。
扩展资料
创Sql代码创建数据库
创建之前判断该数据库是否存在
if exists (select * from sysdatabases where name='databaseName')
drop database databaseName
go
Create DATABASE databasename
on primary-- 默认就属于primary文件组,可省略
(/*--数据文件的具体描述--*/
name=‘databasename_data’,-- 主数据文件的逻辑名称
filename=‘'所存位置:\\databasename_data.mdf’, -- 主数据文件的物理名称
size=数值mb, --主数据文件的初始大小
maxsize=数值mb, -- 主数据文件增长的最大值
filegrowth=数值%--主数据文件的增长率)
log on
(/*--日志文件的具体描述,各参数含义同上--*/
name='databasename_log', -- 日志文件的逻辑名称
filename='所存目录:\\databasename_log.ldf', -- 日志文件的物理名称
size=数值mb, --日志文件的初始大小
filegrowth=数值%--日志文件的增长值)
参考资料来源:百度百科——Sql
参考技术BSQL SERVER 建表时先判断表存在情况如下:
在sqlserver中,创建表之前判断表是否存在,如果存在则删除已有表Sql代码
----SQL-Server
if exists (select 1 from sysobjects where id = object_id('EMP') and type = 'U')
drop table S_Evaluate go --CREATE Table: EMP create table EMP( Id numeric
identity, -- 评估ID Conclusion text null --结论
constraint PK_S_EMP primary key nonclustered(Id) )
go ORACLE 数据库
但是在oracle中却没有。如果直接使用drop table那么如果表不存在会报错,导致后续语句无法运行。因此可以通过一个存储过来来进行判断。
主要是查询all_tables表的TABLE_NAME和OWNER,如果表存在,则执行execute immediate 'drop table TABLE_NAME';
Sql代码
--判断表是否存在,如果存在则删除
declare
num number;
begin select count(1) into num from all_tables where TABLE_NAME = 'EMP' and
OWNER='SCOTT';
if num=1 then
execute immediate 'drop table EMP';
end if; end; / --创建表
CREATE TABLE EMP
(EMPNO NUMBER(4) NOT NULL,
ENAME VARCHAR2(10),
JOB VARCHAR2(9),
MGR NUMBER(4),
HIREDATE DATE,
SAL NUMBER(7, 2),
COMM NUMBER(7, 2),
DEPTNO NUMBER(2));
现在使用DB2,网上找了很久也没个好方法,基本上用简单的sql语句来实现是不大可能的,能找到的方法都是自己写存储过程实现
删除表的如下:
Sql代码
CREATE PROCEDURE ExistsTest(IN TableName varchar(50),OUT iReturn int)
LANGUAGE SQL
P1: BEGIN
DECLARE stmt VARCHAR(200);
IF EXISTS (select * from sysibm.systables where TID <> 0 and name = TableName ) THEN
set stmt ='drop table '|| TableName;
PREPARE s1 FROM stmt;
EXECUTE s1;
set iReturn =0;
else
set iReturn =-1;
END IF;
END P1@
END P1后面的@根据所用编辑工具的不同,默认的结束也不一样。测试了一下QUEST CENTRAL FOR DB2,默认是分号,如果想用@自己修改工具的配置吧
由于DB2不像sqlserver那样把所有对象组织到一个sysobjects里,所以想要实现不同的功能就需要修改这个存储过程,
如:
syscat.procedures 存储过程
syscat.tables 表
sysibm.tables 表
syscat.views 视图
sysibm.views 视图
sysibm.tables的表里面的信息比syscat.tables的少,或者说IBM认为你想知道的信息在sysibm.tables里面已经都可以知道了,这个应该是给用户使用的。syscat.tables应该是给系统使用的。
扩展资料:
利用SQL SERVER 建表方法:
1、在没有创建数据库的时候界面的左上角是这样的:数据库文件夹里边包含系统数据库,数据库快照,ReportServer和REportServerTempDB。
2、然后创建一个数据库,数据库的名字可以随意命名,可以是数字,字符,下划线,标点符号,汉字等等。
3、在数据库中创建表,一般采用的是键盘输入的方法建表。点击新建查询。
参考技术C 来点猛的!!!例子如下:if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[cpm_tv]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[cpm_tv]
GO
CREATE TABLE [dbo].[cpm_tv] (
[SN] [int] IDENTITY (1, 1) NOT NULL ,
[Tvname] [nvarchar] (50) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL ,
[Tvauthor] [nvarchar] (50) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL ,
[Tvremark] [nvarchar] (200) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL ,
[Tvispublish] [nvarchar] (4) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL ,
[Tvpath] [nvarchar] (200) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL ,
[Tvcreater] [nvarchar] (50) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL ,
[Tvcreatetime] [datetime] NULL ,
[Tvoldfname] [nvarchar] (50) COLLATE Chinese_Taiwan_Stroke_CI_AS NULL
) ON [PRIMARY]
GO
有点纳闷吧。这是 sql server 生成的,呵呵。 参考技术D use 数据库名
if exists ( select *
from sysobjects
where name = '表名'
and type = 'U')
drop table user_mess
go
create table 表名()本回答被提问者采纳
以上是关于怎么判断sql数据库是不是存在,存在删除的主要内容,如果未能解决你的问题,请参考以下文章