⑴ sql中表的類型
在SQL里,基本表的關鍵字是TABLE,是一張二維表,存放數據集的表。視圖的關鍵字是VIEW,視圖可以理解為虛擬表,里邊是不存放數據的,只是存放一條查詢語句,查詢視圖時顯示的數據都是從基本表中根據條件篩選出來的結果。 其具體定義如下:(1)所謂基本表,是這樣的一種表,它本身是實際存在的,每個表在存儲中可用一個存儲文件來表示(一個基本表就是一個關系),它不是由其他表導出的表。
(2)視圖是資料庫中的虛擬表,由一個或幾個基本表導出,用於讓用戶變換角度來操作基本表。資料庫中只保存視圖的定義,視圖中不存放對應的數據。 (3)導出表:在基本表的基礎上通過定義視圖而生成的表,稱為導出表。導出表是虛表,其本身不存儲於資料庫中,資料庫僅在數據字典中存儲其定義。
視圖(view)是在基本表之上建立的表,它的結構(即所定義的列)和內容(即所有數據行)都來自基本表,它依據基本表存在而存在。一個視圖可以對應一個基本表,也可以對應多個基本表。視圖是基本表的抽象和在邏輯意義上建立的新關系
⑵ sql server中如何創建表類型,並用該表類型創建一張新表。
如果只創建表結構,可用如下語句;
1
select * into 新表 from 舊表 where 1<>1;
如果創建表結構並且同時數據也要,可用如下語句:
1
select * into 新表 from 舊表;
說明:
其中第一句用了1<>1,也就代表條件永遠為false,這樣就表示沒有數據被篩選,所以只是建立了一個空表。
⑶ sql創建數據創建數據類型和表,請高手幫忙啊!!
什麼資料庫? 現在大部分資料庫都有可視化界面. 直接在資料庫建就可以.
⑷ sqlserver怎麼操作自定義表類型
-- ================================
-- 創建和使用自定義表類型
-- ================================
USE master
GO
-- ================================
-- 創建測試資料庫
-- ================================
CREATE DATABASE demo
GO
-- ================================
-- 創建一個表
-- ================================
USE demo
GO
CREATE TABLE Customers
(
Id int NOT NULL,
Name char(10) NULL,
PRIMARY KEY (Id)
)
GO
USE demo
GO
-- ================================
-- 創建自定義表類型
-- ================================
CREATE TYPE dbo.CustomerTable AS TABLE
(
Id int NOT NULL,
Name char(10) NULL,
PRIMARY KEY (Id)
)
GO
-- =================================
-- 直接使用自定義表類型
-- =================================
DECLARE @c CustomerTable
INSERT INTO @c VALUES(1,'Xizhang')
SELECT * FROM @c
-- =================================
-- 在存儲過程中使用自定義表類型
-- =================================
CREATE PROC GetCustomers
(@c CustomerTable READONLY)
AS
INSERT Customers SELECT * FROM @c --將傳過來的參數(其實是一個表)的數據插入到Customers表裡面去
-- =================================
-- 調用該存儲過程,一次性插入4行數據
-- =================================
DECLARE @temp CustomerTable
INSERT INTO @temp VALUES(7,'Xizhang')
INSERT INTO @temp VALUES(2,'Xizhang')
INSERT INTO @temp VALUES(3,'Xizhang')
INSERT INTO @temp VALUES(4,'Xizhang')
EXEC GetCustomers @c=@temp
SELECT * FROM Customers
-- =================================
-- 清理資料庫
-- =================================
USE master
GO
DROP DATABASE demo
GO
看起來不錯對吧,但是你應該馬上想到一個問題,如果說這個存儲過程要在客戶端代碼中調用,那麼該怎麼提供這個參數值呢?
using System.Data.SqlClient;
using System.Data;
class Program
{
static void Main(string[] args)
{
DataTable tb = GetData();
using (SqlConnection conn = new SqlConnection("server=sql2008;database=demo;integrated security=true"))
{
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "GetCustomers";
cmd.CommandType = CommandType.StoredProcere;
SqlParameter param = new SqlParameter("@c", SqlDbType.Structured);//這個類型很關鍵
param.Value = tb;
cmd.Parameters.Add(param);
conn.Open();
cmd.ExecuteNonQuery();
conn.Close();
}
}
Console.WriteLine("完成操作");
Console.Read();
}
private static DataTable GetData()
{
DataTable tb = new DataTable();
tb.Columns.Add("Id",typeof(int));
tb.Columns.Add("Name", typeof(string));
//添加100個客戶資料
for (int i = 0; i < 100; i++)
{
DataRow row = tb.NewRow();
row[0] = i;
row[1] = "Name " + i.ToString();
tb.Rows.Add(row);
}
return tb;
}
}
⑸ SQL創建自定義數據類型問題
sp_addtype中的null或not null只是為該數據類型定義默認的為空性,
舉個例子你就明白了:
通過語句來創建表,假設定義的類型名為mytype1
create table temp
(
Id int not null ,
content mytype1
)
這個語句中,我們沒有顯示的指定content是否可以為空,
當在sp_addtype中指定了not null,那麼現在content列就默認是不可以為空的。
同樣,在sp_addtype中未指定not null,那麼現在content列就是可以為空的。
當我們用如下語句創建表時
create table temp
(
Id int not null ,
content mytype1 null
)
由於我們指定了該列可以為空,那麼我們在sp_addtype里所指定的not null就被忽略掉了(說忽略不太恰當)。
⑹ SQL中如何自定義數據類型
在建完表以後在check約束中進行約束啊。比如說身份證號的欄位為SFZH,則約束就為:([SFZH] like [0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][a-z] or [SFZH] like [0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9][A-Z])
⑺ sql server資料庫在表定義時,如何將欄位數據類型定義成另一個欄位一致的數據類型,不用自定義用戶類型
在表定義時,沒法給指定與其他欄位類型一樣的操作。
但是如果使用 select * into 新表 from 舊表,可以得到一個與原表一樣的數據表結構。
⑻ SQL如何用語句更改欄位的數據類型
SQL如何用語句更改欄位可以用以下語句可以實現:
altertable表名altercolumn欄位名變更後的欄位類型。
注意:
但若是關鍵欄位,帶有主鍵,並且欄位類型為用戶自定義類型,具有默認值的情況下,用上述語句會出現錯誤。
例如:
現假設表為TABLE1,關鍵欄位為FIELD1,主鍵為PK_FIELD1,關鍵欄位的數據類型為用戶自定義數據類型cha_field1,實際為CHAR(10),默認值為dbo.D_field1現要求將欄位類型改為varchar(20),默認值去除錯誤提示如下:
伺服器:消息5074,級別16,狀態1,行1
對象'D_field1'依賴於列'field1'。
伺服器:消息5074,級別16,狀態1,行1
對象'PK_field1'依賴於列'field1'。
伺服器:消息4922,級別16,狀態1,行1
ALTERTABLEALTERCOLUMNfield1失敗,因為有一個或多個對象訪問此列。
⑼ sql server中創建表時各個數據類型時什麼意思
SQL Server 數據類型分類及含義如下:
1、Character 字元串:
(9)sql用戶定義表類型擴展閱讀:
關於SQL數據類型的特徵解析:
在 SQL Server 中,每個列、局部變數、表達式和參數都具有一個相關的數據類型。 數據類型是一種屬性,用於指定對象可保存的數據的類型:整數數據、字元數據、貨幣數據、日期和時間數據、二進制字元串等。
當兩個具有不同數據類型、排序規則、精度、小數位數或長度的表達式通過運算符進行組合時,結果的特徵由以下規則確定:
1、結果的數據類型是通過將數據類型的優先順序規則應用到輸入表達式的數據類型來確定的。 有關詳細信息,請參閱數據類型優先順序 (Transact-SQL)。
2、當結果數據類型為 char、varchar、text、nchar、nvarchar 或 ntext 時,結果的排序規則由排序規則的優先順序規則確定。 有關詳細信息,請參閱排序規則優先順序 (Transact-SQL)。
3、結果的精度、小數位數及長度取決於輸入表達式的精度、小數位數及長度。 有關詳細信息,請參閱精度、小數位數和長度 (Transact-SQL)。