❶ sql導出EXCEL分表(asp)
不用這么麻煩.直接使用bcp導出吧.
bcp 資料庫名.dbo.表名 out 文件路徑 -c -S伺服器名 -U用戶名 -P密碼
例
exec master..xp_cmdshell 'bcp TEMPDB.dbo.TABLE1 out c:\a.xls -c -Slocalhost -Usa -P123'
❷ sqlserver資料庫很大,建立分表能否提升查詢速度
如果有時間欄位,建議做分區表,按時間分區,這樣表從物理上是分開的,但是對外還是一張表.
好處有1.原本的代碼結構不用變2.查詢歷史數據的時候,速度仍然有保障3.如果建立觸發器進行自動分區,理論上不管再用多少年,都不會再需要重新建表a2了
❸ sqlserver 分庫分表怎麼操作
sql server 分庫分表方案&單表分區 教程
http://blog.csdn.net/chenhisen/article/details/50747582
❹ sql 大量數據分表查詢
可以,這個就像你分頁的時候,當一個表的數據量太大, 你就不可能一次性全查出來,得規定查出多少條,然後下一頁的時候再是後面多少條,具體實現就自己寫了。我這里給你個分頁的SQL,oracle的分頁。
SELECT * FROM (
SELECT a.*, ROWNUM rm FROM(
SELECT * FROM tableName
) a WHERE ROWNUM <=10
) WHERE rm>5
這里是查出6~10條數據,你可以按這個思路去做做。
❺ 資料庫一個表數據太多了,如何分表
這個要看你是什麼資料庫。
Oracle 或者 SQL Server 企業版本的, 可以嘗試使用 分區表來處理。
如果對 分區表不熟悉, 或者不高興折騰。
SQL Server 可以嘗試使用 分區視圖的方式來處理。
❻ sqlserver怎麼分庫分表
sql server 2008資料庫分離操作跟sql server 2005是一樣的,以下具體介紹如何分離sql server 資料庫:
1、打開 sql server 控制台(SQL Server Management Studio),然後登錄。
2、登錄時如果知道sa密碼可以使用「SQL Server身份驗證」模式登錄,如果不知道sa密碼可以使用「windows身份驗證」模式登錄就不需要密碼登錄。而sql server 2008的用戶一般是在安裝的時候自定義的用戶,但也可以使用「windows身份驗證」模式登錄。
3、登錄到控制到中之後,找到【資料庫】點擊展開,然後找到你所需要分離的資料庫名稱。選中資料庫【右鍵】-【任務】-【分離】即可。
附件說明:分離資料庫一般是需要將資料庫拷貝到其他機器或者是移動磁碟時和不需要使用該資料庫的情況下才做資料庫分離。資料庫一旦分離之後所對應的軟體將無法正常使用和打開資料庫。如果需要重新將資料庫還原到資料庫控制台中,選中【資料庫】-【右鍵】-【附加】,找到你所要附件的數據所在的磁碟路徑,選擇以「.MDF」為後綴的文件即可。
❼ sql根據id自動分表存儲
我感覺你這個需求使用分區表來實現會更好一些
但如果你要使用你的方法也是可以的
create table x_a(id int,name varchar(200));
go
create procere changetablename
@oldtable as nvarchar(200),
@newtable as nvarchar(200)
as
declare @sqlstr varchar(2000),@cretri varchar(8000)
begin
exec sp_rename @oldtable,@newtable
set @sqlstr='create table '+@oldtable+'(id int,name varchar(200))'
exec(@sqlstr)
drop trigger t_x_a_id;
set @cretri='create trigger t_x_a_id
on x_a
for insert
as
declare @idnum int,@tbid int,@sqlstr varchar(200),@tbn varchar(200);
select @idnum=id%10,@tbid=round(id/10,0) from inserted;
set @sqlstr='+'''x_a'''+'+cast(@tbid as varchar(20));
set @tbn='+'''x_a'''+';
if @idnum=0
begin
exec dbo.changetablename @tbn,@sqlstr;
end'
exec(@cretri)
end
go
create trigger t_x_a_id
on x_a
for insert
as
declare @idnum int,@tbid int,@sqlstr varchar(200),@tbn varchar(200);
select @idnum=id%10,@tbid=round(id/10,0) from inserted;
set @sqlstr='x_a'+cast(@tbid as varchar(20));
set @tbn='x_a';
if @idnum=0
begin
exec dbo.changetablename @tbn,@sqlstr;
end
go
❽ sqlserver資料庫怎麼分表
分三個表就可以了,用三級id關聯
❾ MySQL 分表的 SQL 語句如何生成比較好
需要對 MySQL 資料庫表進行分表,看如下建表 SQL:
CREATE TABLE `gift_user_log_1` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`giftid` int(11) NOT NULL,
`userid` int(11) NOT NULL,
`total` int(11) NOT NULL,
`updated_at` timestamp NULL DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
如果需要建 50 張這樣的表,豈不是復制粘貼 50 次,然後手動修改表名的序號,顯然不可行,但是 PHP 框架本身沒有提供資料庫這方面的工具。