谁能帮忙写个这样的SQLServer的存储过程?数据表名Aed108,列名,dd_date(datetime类型),dm(int类型),主键:(dd_date,dm复合),存储过程

my_yinger 2003-09-29 03:08:35
谁能帮忙写个这样的SQLServer的存储过程?数据表名Aed108,列名,dd_date(datetime类型),dm(int类型),主键:(dd_date,dm复合),存储过程接收2个参数,一个为datetime型的当月最后一天的日期(例如2003-09-30),另一个为int型的数值。执行结果是在表Aed108先判断是否有这个月的数据,如果没有就增加当月的数据,dd_date分别为1号到月末,dm为同一个数值。

CREATE PROCEDURE dbo.dt_Ae108DataSet
.
.
.
.
.
...全文
55 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
my_yinger 2003-10-05
  • 打赏
  • 举报
回复
虽然各位写的都没通过,但我根据大家的启发,我自己写完了,大家写的对我还是很有帮助的,在此谢谢各位了
my_yinger 2003-09-30
  • 打赏
  • 举报
回复
aierong(皑婀瑢-数据库XML.NET联盟会处长)

写的提示:

错误260:Disallowed implicit conversion from data type datetime to data type int ,table 'ssmis.dbo.aed108'.use the convert function to run this query

另外,在表中再加几个列,例如dx1,dxwv....这些列都是可以为空的列。加入时不必赋值。

各位写的都没通过啊,怎么办啊
my_yinger 2003-09-29
  • 打赏
  • 举报
回复

pengdali(大力 V3.0), 的也是只加入了这一天啊,

sdhdy(大江东去...) ,的提示:错误213:出入错误;列名或提供的数目也表定义不匹配

其它朋友的我还在试,谢谢大家帮忙
aierong 2003-09-29
  • 打赏
  • 举报
回复
create procedure dt_ae108dataset
@dd_date datetime,@dm int
as
declare @dd datetime
if not exists(select * from Aed108 where month(dd_date)=month(@dd_date))
begin
/*先计算出该月得第一天*/
select @dd=dateadd(month,-1,dateadd(day,1,@dd_date))
while datediff(day,@dd,@dd_date)<=0
begin
insert into aed108 select @dd,@dm
/*望后加一天*/
select @dd=dateadd(day,1,@dd)
end
end


--run,记得输入月份得最后一天
exec dt_ae108dataset '2003-09-30',具体数值
aierong 2003-09-29
  • 打赏
  • 举报
回复


create procedure dt_ae108dataset
@dd_date datetime,@dm int
as
declare @n tinyint,@dd datetime
select @n=1
if not exists(select * from Aed108 where month(dd_date)=month(@dd_date))
begin
/*先计算出该月得第一天*/
select @dd=dateadd(month,-1,dateadd(day,1,@dd_date))
while @n<=day(@dd_date)
begin
insert into aed108 select @dd,@dm
select @n=@n+1
/*望后加一天*/
select @dd=dateadd(day,1,@dd)
end
end


--run
exec dt_ae108dataset '2003-09-30',具体数值
my_yinger 2003-09-29
  • 打赏
  • 举报
回复
pengdali(大力 V3.0),

写的也只是加入1天的啊
my_yinger 2003-09-29
  • 打赏
  • 举报
回复
bigddaddy(隐者) ,

1、我说本月,还要排除年的问题啊,当然可以这么写
if not exists( select * from Aed108
where year(dd_date) like datepart(year,@dt_userdate)
AND month(dd_date) like datepart(month,@dt_userdate))

2、但关键的是下面,你写的是加入这一天的数据,我的意思是加入一个月的,例如9月,那么就要加入1~30天30条记录!日期分别是2003-09-01~2003-09-30啊,同样10月的话就加入1~31天31条数据啊
sdhdy 2003-09-29
  • 打赏
  • 举报
回复
CREATE PROCEDURE dbo.dt_Ae108DataSet
@dd_date datetime,
@dm int
as
if not exists(select 1 from Aed108 where year(dd_date)=year(@dd_date) and month(dd_date)=month(@dd_date))
while @dd_date>=dateadd(month,-1,dateadd(dd,1,@dd_date))
begin
insert Aed108 select @dd_date,@dm
set @dd_date=@dd_date-1
end
pengdali 2003-09-29
  • 打赏
  • 举报
回复
CREATE PROCEDURE dbo.dt_Ae108DataSet
@a datetime,
@b int
as
if not exists(select 1 from aed108 where datediff(month,dd_date,@a)=0)
insert aed108 (dd_dat,dm) values(@a,@b)
bigddaddy 2003-09-29
  • 打赏
  • 举报
回复
create procedure dt_ae108dataset @dd_date datetime,@dm int as
if not exists(select * from Aed108 where month(dd_date)=month(@dd_date))
insert into aed108 values (@dd_date,@dm)
PowerBI系列之Power Query专题1.  获取数据 数据源种类介绍和获取Excel数据源输入数据和拷贝数据:创建辅助表解析Json/XML数据格式获取Web网页数据和URL添加动态参数连接数据的四种模式:Import、DirectQuery、Live Connection、Dual双 属于混合模式连接数据库:Sql server、 Mysql(直连但是必须先安装一个mysql插件)DirectQuery直连查询:Sql serverODBC方式获取数据表关联或多个Sql或调用存储过程获取数据SQL中动态传参和自定义函数: sql中使用参数或数据库称使用参数连接Sharepoint和OneDrive数据源连接Dataset和Dataflow 替换本地数据源为Sharepoint数据源并保留数据处理操作 终止当前数据刷新Loading:Cancel Query数据源设置-重置数据连接凭证PBIDS连接数据源创建和使用报表模块(输入或值列表)利用报表模板和参数控制线下报表数据权限DirectQuery启用自动页面刷新和更改检测管理聚合表提高DirectQuery查询性能动态M查询参数提高DirectQuery查询性能添加数据刷新时间 DateTime.LocalNow()和Getdate()2.  数据清洗和M语言M语言和官方文档介绍PowerQuery中查阅M函数:=#shared, Ctrl+Space提示数据清洗之常用技能:提升标题、更改数据类型、保留删除错误或空行,删除重复项、选择列和删除列、填充单元格、合并列、拆分、提取、替换、条件替换、添加自定义列,添加条件列、添加索引列、分组、添加年月日列、追加和合并查询透视和逆透视以及转置合并单元格的Excel文件处理导入文件夹中多Excel文件并合并解决多文件合并中列顺序不一致使用参数和函数批量导入文件 文本中提取中文、英文、数字等处理双引号转义 列拆分详解解决改变错误解决列丢失错误动态显示、排序和重命列为所有添加前缀字母大写和分隔符调整Trim标题列中的多余空格如何处理load数据错误为什么load的Excel数据有null空行为什么load的Excel数据标题在第二行灵活添加占位符规范同类相似数据数据按多列排序为分组添加Index序号分组内值合并诊断工具分析数据处理过程PowerQuery小技巧分享 新冠病例活动轨迹地图标识 

34,587

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧