单表的列信息(序号)操作

--use wangkejidatabase

use demodtcms

SELECT a.colid,* from syscolumns a inner join sysobjects d on a.id=d.id and d.xtype=‘U‘ and d.name =‘gggggggggg‘ left join syscomments e on a.cdefault=e.id --WHERE a.name=‘asda11‘

use wangkejidatabase

SELECT a.colid,* from syscolumns a inner join sysobjects d on a.id=d.id and d.xtype=‘U‘ and d.name =‘gggggggggg‘ left join syscomments e on a.cdefault=e.id --WHERE a.name=‘asda11‘

use demodtcms
select * from sysobjects where type=‘F‘ and parent_obj = OBJECT_ID(‘test‘)

use wangkejidatabase
--外键信息
select fk.name fkname , ftable.name ftablename, cn.name fkcol, rtable.name ftablename,ObjectProperty(fk.id,‘CnstIsUpdateCascade‘) updatCase,ObjectProperty(fk.id,‘CnstIsDeleteCascade‘) deletCase from sysforeignkeys
join sysobjects fk
on sysforeignkeys.constid = fk.id
join sysobjects ftable
on sysforeignkeys.fkeyid = ftable.id
join sysobjects rtable
on sysforeignkeys.rkeyid = rtable.id
join syscolumns cn
on sysforeignkeys.fkeyid = cn.id and sysforeignkeys.fkey = cn.colid

--外键被参考表
SELECT 主键列ID=b.rkey
,主键列名=(SELECT name FROM syscolumns WHERE colid=b.rkey AND id=b.rkeyid)
,外键表ID=b.fkeyid
,外键表名称=object_name(b.fkeyid)
,外键名称= c.name
,外键列ID=b.fkey
,外键列名=(SELECT name FROM syscolumns WHERE colid=b.fkey AND id=b.fkeyid)
,级联更新=ObjectProperty(a.id,‘CnstIsUpdateCascade‘)
,级联删除=ObjectProperty(a.id,‘CnstIsDeleteCascade‘)
FROM sysobjects a
join sysforeignkeys b on a.id=b.constid
join sysobjects c on a.parent_obj=c.id
join syscolumns cn
on b.fkeyid = cn.id and b.fkey = cn.colid
where a.xtype=‘f‘ AND c.xtype=‘U‘
and object_name(b.rkeyid)=‘dt_article‘

DECLARE @dbname1 varchar(250)--要比较的数据库名1
DECLARE @dbname2 varchar(250) --要比较的数据库名2

set @dbname1=‘demodtcms‘
set @dbname2=‘wangkejidatabase‘

create table #fk1(外键名 varchar(250),子表名 varchar(250),子表列 varchar(250),被参考表 varchar(250),被参考列 varchar(250),启用 bit,
删除操作 varchar(50),更新操作 varchar(50))

--use demodtcms
--外键详细信息
insert into #fk1 SELECT
外键名=f.name --AS foreign_key_name
,子表名=OBJECT_NAME(f.parent_object_id) --AS table_name
,子表列=COL_NAME(fc.parent_object_id, fc.parent_column_id) --AS constraint_column_name
,被参考表=OBJECT_NAME (f.referenced_object_id) ---AS referenced_object
,被参考列=COL_NAME(fc.referenced_object_id, fc.referenced_column_id) --AS referenced_column_name
,启用=is_disabled
,删除操作=delete_referential_action_desc
,更新操作=update_referential_action_desc
FROM sys.foreign_keys AS f
INNER JOIN sys.foreign_key_columns AS fc
ON f.object_id = fc.constraint_object_id
WHERE f.parent_object_id in (SELECT id from sysobjects WHERE xtype=‘U‘) ORDER BY f.name
--= OBJECT_ID(‘‘test‘‘)

SELECT * FROM #fk1

时间: 2024-10-31 00:11:12

单表的列信息(序号)操作的相关文章

web day19 Service层处理事务(利用ThreadLocal),TxQueryRunner小工具,单表练习(增删改查操作),分页

Service事务 DAO中不是处理事务的地方,因为DAO中的每个方法都是对数据库的一次操作 在Service中不应该出现Connection,它应该只在DAO中出现, 因为它是JDBC的东西,JDBC的东西是用来连接数据库的 修改JdbcUtils 我们把对事务的开启和关闭放到JdbcUtils中,在Service中调用JdbcUtils的方法来完成事务的处理, 但在Service中就不会再出现Connection这一"禁忌"了. 代码 public class JdbcUtils

mysql查看表中列信息

查看所有数据库中所有表的数据库名和表名 SELECT `TABLES`.`TABLE_SCHEMA`, `TABLES`.`TABLE_NAME` FROM `information_schema`.`TABLES` 查看所有数据库中所有基本表的数据库名和表名 SELECT `TABLES`.`TABLE_SCHEMA`, `TABLES`.`TABLE_NAME` FROM `information_schema`.`TABLES` WHERE `TABLES`.`TABLE_TYPE` =

表及列信息查询

查某个用户下指定表名查表的基本信息,不指定表名则查该用户下所有的表,segment_type 指定为表类型 也有index 类型 select a.table_name 表名, b.created 创建时间, b.last_ddl_time 最后修改时间, c.last_analyzed 最后分析时间, c.tablespace_name 表空间, c.num_rows 行数, --要经过表分析后才精确 分析表可以用 analyze 也可以用系统包 dbms_stats d.bytes / 10

17-2 orm单表操作和多表操作

参考:https://www.cnblogs.com/liwenzhou/p/8660826.html 一  ORM单表操作 1 增删改查 1 1. 查询 2 1. 查所有 3 models.Publisher.objects.all() 4 2. 查某个具体的记录 5 models.Publisher.objects.get(id=1) --> 注意查询条件不成立就报错 6 2. 删除一条记录 7 models.Publisher.objects.get(id=1).delete() 8 3.

ORM单表操作

本文目录 一.ORM简介 二.全局配置 三.搞搞搞 一.ORM简介 .ORM是“对象-关系-映射”的简称 .MVC或者MTV框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以,轻松更换数据库,这极大的减轻了开发人员的工作量,不需要面对因数据库变更而导致的无效劳动. 二.全局配置 .单表是相对简单的Django项目,我们再次进行对单表的增删改查操作,话不多说,项目开始. 1.setting.py 文件配置静态路径.

Mybatis实现单表增删改查操作

mybatis是对持久层进行了封装.mybatis文档地址:https://mybatis.org/mybatis-3/zh/index.html 下面实现单表的增删改查操作. 1.新建maven项目命名为mybatis.并在pom.xml中引入相关依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"

Hibernate学习笔记(一)--&gt;数据库单表操作

Hibernate框架是一个全ORM映射框架,是一个非常流行的数据库操作框架之一,现在比较流行的还有MyBatis半ORM映射框架 在MyEclipse IDE开发工具中,可以很轻松的搭建Hibernate框架. 一.搭建一个项目 1.首先在MyEclipse中搭建一个web项目. 2.选中项目右键-->myeclipse-->Project Facets-->找到hibernate.这样就为项目添加了hibernate支持 3.打开hibernate.cfg.xml配置文件,在可视化编

数据库:数据操作-单表查询

一 单表查询的语法 select 字段1,字段2....from 表名 where 条件 group by field having 筛选 order by field limit 限制条数 二 关键字的执行优先级(重点) 关键字的执行优先级 from where group by having select distinct order by limit 1.找到表:from 2.拿着where指定的约束条件,去文件/表中取出一条条记录 3.将取出的一条条记录进行分组group by,如果没有

Django学习【第6篇】:Django之ORM单表操作(增删改查)

django之数据库表的单表查询 一.添加表记录 对于单表有两种方式 # 添加数据的两种方式 # 方式一:实例化对象就是一条表记录 Frank_obj = models.Student(name ="海东",course="python",birth="2000-9-9",fenshu=80) Frank_obj.save() # 方式二: models.Student.objects.create(name ="海燕",co