首页 > 数据库 >如何批量给Sqlserver数据库表中的 如:创建时间设置为自动填充约束

如何批量给Sqlserver数据库表中的 如:创建时间设置为自动填充约束

时间:2022-11-16 11:45:48浏览次数:42  
标签:Name 填充 XType Sqlserver update 表中 tname SELECT string

批量给数据库表中的 如:创建时间设置为自动填充约束

1:小知识补充

//-----------sqlserver

1.获取所有数据库名: 
SELECT Name FROM Master..SysDatabases ORDER BY Name 
2.获取所有表名: 
SELECT Name FROM DatabaseName..SysObjects Where XType='U' ORDER BY Name 
XType='U':表示所有用户表; 
XType='S':表示所有系统表; 
3.获取所有字段名: 
SELECT Name FROM SysColumns WHERE id=Object_Id('TableName')

2:代码实现

//----------批量给数据库的表时间字段设置为自动时间
 public async Task<ApiResultDto> InitAddAutoDateTime()
        {
            /*
             SELECT Name FROM Scenic..SysObjects Where XType='U' ORDER BY Name ;
             SELECT isnull( Name,'0')cname FROM SysColumns WHERE id=Object_Id('gsm_send_wx') and name like '%update_date%';
             ALTER TABLE [dbo].[bct_dept_print] ADD  CONSTRAINT [DF_bct_dept_print_update_date]  DEFAULT (getdate()) FOR [update_date]
             */

            List<string> listTableName = await DbScoped.Sugar.Ado.SqlQueryAsync<string>("SELECT Name FROM Scenic..SysObjects Where XType='U' ORDER BY Name");
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < listTableName.Count; i++)
            {
                string tname = listTableName[i];
                string sqlColumunList = $"SELECT isnull( Name,'0')cname FROM SysColumns WHERE id=Object_Id('{tname}') and lower(name)  like '%update_date%' ";
                string gname= await DbScoped.Sugar.Ado.SqlQuerySingleAsync<string>(sqlColumunList);
                if (!string.IsNullOrEmpty(gname))
                {
                  
                    string addTimeSql = $" ALTER TABLE [dbo].[{tname}] ADD  CONSTRAINT [DF_{tname}_update_date]  DEFAULT (getdate()) FOR [update_date]";
                    try
                    {
                       int count= await DbScoped.Sugar.Ado.ExecuteCommandAsync(addTimeSql);
                        if (count>0)
                            sb.Append(tname+",");
                    }
                    catch (Exception ex)
                    {
                        continue;
                    }
                }
            }
            return ApiResultDto.ToResultSuccess(data:sb.ToString());
        }

 

标签:Name,填充,XType,Sqlserver,update,表中,tname,SELECT,string
From: https://www.cnblogs.com/Fengge518/p/16895346.html

相关文章

  • Linux安装ODBC连接SQLServer数据库
    操作系统:Centos7.21、下载ODBC安装包unixODBC-2.3.9.tar.gzfreetds-1.3.9.tar.gz下载这两个压缩包的地址:ftp://ftp.freetds.org/pub/freetds/stable/ftp://ftp.unixodb......
  • SQLServer内置函数实现MD5加密与解密
    SQLServer内置函数实现MD5加密⼀、MD5加密HASHBYTES('加密⽅式','待加密的值')加密⽅式=MD2|MD4|MD5|SHA|SHA1返回值类型:varbinary(maximum8000bytes)⼆、MD5......
  • sqlserver xml 操作:1、使用for xml
    sqlserverxml操作:1、使用forxml一个是侧重介绍forxml模式的,一个是侧重语法及细节参数的forxml(SqlServer)forxml子句的基本语法说实话,老顾觉得其......
  • sqlserver xml 操作:2、对确定结构的xml进行操作
    sqlserverxml操作:2、对确定结构的xml进行操作我们使用的xml有着明确的定义结构,该啥节点,该啥属性,该啥层级,基本在设计之初就已经确定了,很少有确定了结构的xml格式再......
  • sqlserver xml 操作:3、对不确定结构、属性的xml进行处理
    sqlserverxml操作:3、对不确定结构、属性的xml进行处理在平时使用过程中,xml的结构一般都是已经确定了的,所以我们读取并不是很麻烦的事,但如果一旦结构或数据不确定,......
  • sqlserver FOR XML查询参数path的实例
     SQLSERVER中XML查询:FORXML指定PATH前言在SQLSERVER中,XML查询可以指定RAW,AUTO,EXPLICIT,PATH。本文用一些实例介绍SQLSERVER中指定PATH的XML查询。PA......
  • 把XML数据插入到SQL Server数据库的表中
     把XML数据插入到SQLServer数据库的表中我们可以通过使用系统存储过程sp_xml_preparedocument的OPENXML函数把XML文档中的数据插入数据库中。其中,系统存储过程sp_......
  • 力扣24 两两交换链表中的节点
    题目:给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。示例:输入:head=[1,2,3,4]......
  • SQLserver 建表语句
    CREATETABLE[dbo].[Dim_Tyc_Supplier_Main_Staff_Info]( [StaffId][nvarchar](255)NOTNULL, [SupplierCode][nvarchar](255)NULL, [Position1][nvarchar](255)NUL......
  • SqlServer入门知识-创建临时表
    https://zhuanlan.zhihu.com/p/562721751平时会直接在正常的库里面直接建表,好像和这个不一样,了解下。平时用时会直接在库里备份数据,然后删掉备份的表。属于数据备份,不是真......