t-sql if exists begin end 报错

zhujinpengliang 2013-10-30 05:01:54
use master
go
if exists(select * from sysdatabases where name='ttt')
begin
print '已经存在'
end
else
begin
use master
go
create database ttt
go
use ttt
if exists(select * from sysobjects where name='T_News' and xtype ='U')
begin
print '该表已经存在'
end
else
begin
create table T_News (
ID int not null ,
Title varchar(50) not null,
passwd varchar not null
)
end
end


////////
消息 102,级别 15,状态 1,第 7 行
'master' 附近有语法错误。
消息 102,级别 15,状态 1,第 14 行
'end' 附近有语法错误。
...全文
355 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhujinpengliang 2013-10-30
  • 打赏
  • 举报
回复
多谢各位
發糞塗牆 2013-10-30
  • 打赏
  • 举报
回复
我个人比较偏向这种,可以运行的,不存在才创建,可以反复运行
use master     
go
IF db_id('ttt')IS  NULL
CREATE DATABASE ttt
go
USE ttt
go
IF OBJECT_ID('T_News','u')IS  NULL
CREATE TABLE T_News
(
 ID int not null ,
Title varchar(50) not null,
passwd varchar not null
    ) 
zhujinpengliang 2013-10-30
  • 打赏
  • 举报
回复
引用 3 楼 DBA_Huangzj 的回复:
[quote=引用 2 楼 hdhai9451 的回复:]
use master     
go

if exists(select * from sysdatabases where name='ttt')  
begin
print '已经存在'
end
else
begin
    --use master
    --go
	create database ttt
	--go
	--use ttt
	if exists(select * from sysobjects where name='T_News' and xtype ='U') 
	begin
	   print '该表已经存在'     
	end
	else
	begin
		create table  T_News (
		 ID int not null ,
		Title varchar(50) not null,
		passwd varchar not null
			) 
	end
end
要去掉四行才执行.
但是T_news就创建在master里面了,本身他这个脚本就不合理[/quote] 请教一下要实现我这个逻辑要求该怎么写合理。
-Tracy-McGrady- 2013-10-30
  • 打赏
  • 举报
回复

  if exists(select * from sys.databases where name='ttt') 
    print '数据库已经存在'
  else
    create database ttt
  go
  use ttt
  go
  if exists(select * from sys.objects where name='T_News' and type ='U') 
    print '该表已经存在于ttt数据库' 	    
  else
    create table T_News(ID int not null,Title varchar(50) not null,passwd varchar not null) 
  go
  
發糞塗牆 2013-10-30
  • 打赏
  • 举报
回复
引用 2 楼 hdhai9451 的回复:
use master     
go

if exists(select * from sysdatabases where name='ttt')  
begin
print '已经存在'
end
else
begin
    --use master
    --go
	create database ttt
	--go
	--use ttt
	if exists(select * from sysobjects where name='T_News' and xtype ='U') 
	begin
	   print '该表已经存在'     
	end
	else
	begin
		create table  T_News (
		 ID int not null ,
		Title varchar(50) not null,
		passwd varchar not null
			) 
	end
end
要去掉四行才执行.
但是T_news就创建在master里面了,本身他这个脚本就不合理
Andy__Huang 2013-10-30
  • 打赏
  • 举报
回复
use master     
go

if exists(select * from sysdatabases where name='ttt')  
begin
print '已经存在'
end
else
begin
    --use master
    --go
	create database ttt
	--go
	--use ttt
	if exists(select * from sysobjects where name='T_News' and xtype ='U') 
	begin
	   print '该表已经存在'     
	end
	else
	begin
		create table  T_News (
		 ID int not null ,
		Title varchar(50) not null,
		passwd varchar not null
			) 
	end
end
要去掉四行才执行.
Andy__Huang 2013-10-30
  • 打赏
  • 举报
回复
begin 和 end 之间不能用go执行语句

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧