得到SQLServer某库表格的主外键
- 2011年04月28日 [已被偷窥 4,474 次]
今天有学员问这个问题,两个人分别建库建表,结果将近一百个表,无数个外键彻底乱套了
要弄个对比慢慢核对,真是… …
很久没写了,都快忘了SQL结构了,捣鼓了好一会才弄出来
放在这里吧
SELECT object_name(fkeyid) 表,object_name(cons[……]
按 ‘ SQL ’ 标签归档
今天有学员问这个问题,两个人分别建库建表,结果将近一百个表,无数个外键彻底乱套了
要弄个对比慢慢核对,真是… …
很久没写了,都快忘了SQL结构了,捣鼓了好一会才弄出来
放在这里吧
SELECT object_name(fkeyid) 表,object_name(cons[……]
错误提示:
此数据库没有有效所有者,因此无法安装数据库关系图支持对象。若要继续,请首先使用“数据库属性”对话框的“文件”页或 ALTER AUTHORIZATION 语句将数据库所有者设置为有效登录名,然后再添加数据库关系图支持对象。
sql2000备份的数据库还原到sql2005后,选择“[……]
今天项目要求在同一服务器上安装SQL2000和SQL2005,安装过程很简单,SQL2000默认,SQL2005指定实例名称,结果2000ok了,2005本机可以访问,远程死活连不上,md
1.2000默认端口1433,2005需要改改,改了就需要设置SQL Browser,不然over找不到端口[……]
字符串转换成多行
CREATE TABLE t_str_row AS
SELECT id,
MAX(decode(rn, 1, col, NULL)) ||
MAX(decode(rn, 2, ‘,’ || col, NULL)) ||
MAX(decode(rn, 3, ‘,’ ||[……]
字符串转换成多列
其实际上就是一个字符串拆分的问题。
CREATE TABLE t_str_col AS
SELECT ID,c1||’,’||c2||’,’||c3 AS c123
FROM t_col_str;
SELECT * FROM t_str_col;
1)s[……]
多行转换成字符串
CREATE TABLE t_row_str(
ID INT,
col VARCHAR2(10));
INSERT INTO t_row_str VALUES(1,’a’);
INSERT INTO t_row_str VALUES(1,’b’);
INSERT[……]
多列转换成字符串
CREATE TABLE t_col_str AS
SELECT * FROM t_col_row;
这个比较简单,用||或concat函数可以实现:
SELECT concat(‘a’,’b’) FROM dual;
1)|| OR concat
适用范围[……]
行转列
CREATE TABLE t_row_col AS
SELECT id, ‘c1’ cn, c1 cv
FROM t_col_row
UNION ALL
SELECT id, ‘c2’ cn, c2 cv
FROM t_col_row
UNION ALL
SELECT[……]
一 | 二 | 三 | 四 | 五 | 六 | 日 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 |