SQL Server数据库操作与Transact-SQL示例

3星 · 超过75%的资源 需积分: 10 3 下载量 177 浏览量 更新于2024-09-26 收藏 78KB DOC 举报
"这是关于SQL Server语句的一个综合集合,涵盖了创建、删除数据库,查询系统表,以及执行数据表的各种操作,如创建含约束的表,根据已有表创建新表等。" 在SQL Server中,数据库是存储数据的核心,管理数据库是数据库管理员的重要任务。创建数据库的语句是`CREATE DATABASE`,例如`CREATE DATABASE banksql`,这会在服务器上创建一个名为`banksql`的新数据库。如果不再需要某个数据库,可以使用`DROP DATABASE`语句删除,如`DROP DATABASE banksql`。在数据库之间切换则使用`USE`语句,如`USE banksql`。 系统表提供了关于数据库结构和元数据的信息。在SQL Server中,`syscolumns`表包含了所有表的列信息,而`sysusers`表记录了数据库的用户。例如,查询`syscolumns`表中名为'account_number'的列信息,可以使用`SELECT * FROM dbo.syscolumns WHERE name='account_number'`;查询`sysusers`表的所有信息,用`SELECT * FROM dbo.sysusers`。 数据定义语言(DDL)是SQL中用于创建和修改数据库对象的部分,如创建表。创建一个简单的表`branch`,包含`branch_name`、`branch_city`和`assets`字段,可以使用如下语句: ```sql CREATE TABLE branch ( branch_name char(15) NOT NULL, branch_city char(30), assets integer ) ``` 若要创建带有主键和检查约束的表,例如`account`,代码如下: ```sql CREATE TABLE account ( account_number char(15) NOT NULL, branch_name char(30), balance integer, PRIMARY KEY (account_number), CHECK (balance >= 0) ) ``` 表的复制是常见的操作,可以基于现有表创建新表。如仅选取`account_number`和`balance`字段创建新表`newtable`: ```sql SELECT account_number, balance INTO newtable FROM account ``` 跨数据库的表复制也支持,例如将`bank.dbo.account`表的所有数据复制到`banksql.dbo.account`: ```sql SELECT * INTO banksql.dbo.account FROM bank.dbo.account ``` 这个集合还涉及到了其他表,如`loan`、`borrower`、`customer`、`depositor`,显示了在不同数据库间复制表数据的通用过程。 这些SQL Server语句展示了如何有效地管理数据库和表,包括创建、查询、修改和复制数据,对于数据库管理和开发人员来说是必备的技能。理解和掌握这些语句能够帮助他们在实际工作中更高效地操作和管理SQL Server数据库。