sql表查詢列數
『壹』 如何通過sql語句查詢出表中的列數
是MSSQL SERVER吧,
在MASTER庫里或你自己的庫里,不是有一些默認的表嗎,就是記錄這些信息的。記不住了。自己找找看。
『貳』 如何在sqlserver中獲取表的所有列信息
microsoft sql server management studio中展開對應表下面的列信息不就可以看到列的詳細信息了么?當然這是可以的,但這里我們主要講的時如何利用sql語句來查詢指定表的列信息。
利用sql語句來查詢列信息,就是要用到系統視圖sys.columns,這個視圖記錄了資料庫中所有表,視圖,表值函數等的所有列信息。我們可以利用語句select * from sys.columns來查看這個視圖返回的信息。
sys.columns返回的列比較多,大部分情況下很多列的信息我們可能用不到,下面我們只解釋一下比較常用的列的信息。
1,object_id--這個列是比較重要的,它是返回當前列所屬表的ID。利用它,我們就可以查詢指定表的所有列信息,比如下面的sql語句是查詢表table1的所有列信息。
select * from sys.columns where object_id=object_id('table1')
2,name--該列的列名。
3,column_id--該列在資料庫中的ID,注意,資料庫中任何對象的ID都是唯一的。
4,system_type_id--該列的類型的ID,和下面max_length,precision,scale三列一起可以來舉個示例。
5,max_length--該列的最大長度
6,precisionp--如果這列是數值列,那麼這是該列的精度,否則就是0
7,scale--如果這列是數值列,那麼這就是列的小數位數,否則就是0
system_type_id,max_length,precision,scale四列結合系統視圖sys.types一起我們來舉個示例。
如果我們要查詢表table1的所有列,及列的類型,列的精度,列的小數位數,sql語句如下:
select a.name,b.name,a.max_length,a.precision,a.scale
from sys.columns a left join sys.types b on a.user_type_id=b.user_type_id
where a.object_id=object_id('table1')
8,is_nullable--該列是否可以為null
9,is_identity--該列是否是標識列
10,is_computed--該列是否是計算列。利用該列,我們也就可以查詢某個表的所有計算列了,比如我們要查詢表table1中的所有計算列,sql語句如下:
select * from sys.columns where object_id=object_id('table1') and is_computed=1
sys.columns視圖中常用的列就是這10列了,其它列的信息大家可以到SQLServer 2005聯機叢書中查詢。
『叄』 sql語句查詢一個表的列數
看的出來你初學,可以先看看資料庫基礎,以EXCEL表格的方法給你講一遍。
count(name) 查找出來的行數(看成EXCEL中以某一些條件找出來的行數)
syscolumns 表的名字 (看成EXCEL中的工作表A名)
id 表裡的一個欄位 (看出EXCEL中的某一列)
sysobjects 表的名字 (看成EXCEL中的工作表B名)
xtype='u' 一個欄位=U (看出EXCEL中的某一列=U這個字元)
『肆』 SqlServer如何查詢表的列數
select count(name) from syscolumns
where id=( select id from sysobjects where name='表名' and xtype='U')
說明:select id from sysobjects where name='表名' and xtype='U' 從sysobjects 里查詢表類型為U(非系統)的表的id ,假設查到的是 1002 ;
select count(name) from syscolumns where id=1002 查的是系統列syscolumns 里表id是1002的列數。
你可以隨便建個表,然後分步運行這兩句看看
『伍』 如何利用SQL語句查看某一個表全部列或單個列的屬性
exec sp_columns 表名 --返回某個表列的信息
exec sp_help 表名 --查看某個表的所有信息
這些是系統的存儲過程
例如:
用SQL語句查詢一個數據表所有欄位的類型可以參考下面的代碼:
SELECT
name AS column_name,TYPE_NAME(system_type_id) AS column_type,
(5)sql表查詢列數擴展閱讀:
更新:update table1 set field1=value1 where 范圍
查找:select * from table1 where field1 like 』%value1%』 (所有包含『value1』這個模式的字元串)
排序:select * from table1 order by field1,field2 [desc]
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
『陸』 sql語句查詢表內數據條數
select count(*) from 表名
在sql中會把*解析為相對應的列,我們不建議用*,這樣會加重sql負擔,這樣寫才是最好的:select count(列名,一列就行) from 表名。
由 SQL 查詢程序獲得的結果被存放在一個結果集中。大多數資料庫軟體系統都允許使用編程函數在結果集中進行導航,比如:Move-To-First-Record、Get-Record-Content、Move-To-Next-Record 等等。
(6)sql表查詢列數擴展閱讀:
sql語言特點:
1、綜合統一:
SQL語言集數據定義語言DDL,數據操縱語言DML、數據控制語言DCL的功能於一體
2、高度非過程化:
用SQL語言進行數據操作,只要提出「做什麼」,而無需知名」怎麼做「,因此無需了解存取路徑,存取路徑的選擇語句SQL的操作過程由系統自動完成
3、面向集合的操作方式
SQL語言才採用集合操作方式,不僅操作對象,查找結果可以是元組的集合,而且一次插入、刪除、更新操作的對象也就可以是元組的集合
4、以同一種語言結構提供多種使用方式
SQL語言既是自含式語言,又是嵌入式語言。作為自含式語言,他能給獨立地用戶聯機交互的使用方式,作為嵌入式語言,它能夠嵌入到高級語言程序中,供程序員設計程序時使用。
『柒』 sql 查詢一個表中有多少條數據
1、首先在電腦中打開sql,寫上關鍵字Select後,寫上投影列,並且定義數據源,如下圖所示。
『捌』 sql查詢結果怎麼按指定列數依次排列
with tmp as
(
select row_number() over(order by FENTRYID) rn,FENTRYID
from 表
)
select t1.FENTRYID as FENTRYID1,t2.FENTRYID as FENTRYID2,t3.FENTRYID as FENTRYID3
from tmp t1
left join tmp t2 on t2.rn=t1.rn+1
left join tmp t3 on t3.rn=t1.rn+2
where t1.rn%3=1
order by t1.FENTRYID
這是轉成3列的,如果列數要變化,上面的語句要調整
『玖』 sql怎麼查詢一個資料庫所有表列數
--讀取庫中的所有表名
select name from sysobjects where xtype='u'
--讀取指定表的所有列名
select name from syscolumns where id=(select max(id) from sysobjects where xtype='u' and name='表名')
獲取資料庫表名和欄位
sqlserver中各個系統表的作用
sysaltfiles 主資料庫 保存資料庫的文件
syscharsets 主資料庫 字元集與排序順序
sysconfigures 主資料庫 配置選項
syscurconfigs 主資料庫 當前配置選項
sysdatabases 主資料庫 伺服器中的資料庫
syslanguages 主資料庫 語言
syslogins 主資料庫 登陸帳號信息
sysoledbusers 主資料庫 鏈接伺服器登陸信息
sysprocesses 主資料庫 進程
sysremotelogins主資料庫 遠程登錄帳號
syscolumns 每個資料庫 列
sysconstrains 每個資料庫 限制
sysfilegroups 每個資料庫 文件組
sysfiles 每個資料庫 文件
sysforeignkeys 每個資料庫 外部關鍵字
sysindexs 每個資料庫 索引
sysmenbers 每個資料庫 角色成員
sysobjects 每個資料庫 所有資料庫對象
syspermissions 每個資料庫 許可權
systypes 每個資料庫 用戶定義數據類型
select 列名=name from syscolumns where id=object_id(N'要查的表名')