删除包含汉字的记录

Declare @temp int
Declare @memberName varchar(255)
Declare @MemberID int
declare @tempstr varchar(5000)
DECLARE authors_cursor CURSOR FOR
SELECT MemberID,MemberName
FROM Member  where MemberID>=100000

open authors_cursor

fetch next from authors_cursor  into @MemberID, @memberName
while @@fetch_status=0
begin
--print @memberName

--set @tempstr=
--瓒呯骇濂崇敓 鎯婅壋濠€濞滄按妗惰叞
set @temp=dbo.find_regular_expression(@memberName,'([/u4e00-/u9fa5]|[/uFE30-/uFFA0]|[/u0800-/u4e00]|[-]){1,50}',0)

/*if @temp=1  --合法
 begin
 update Member set Valid=0 where MemberID=@MemberID
 end
else */
if @temp=1
 begin
 --delete Member  where MemberID=@MemberID
 delete Member where Current of authors_cursor
 end
fetch next from authors_cursor into @MemberID, @memberName
end
--print @temp


CLOSE authors_cursor
DEALLOCATE authors_cursor

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
旋转变压器---数字转换器作为现代伺服系统中被广泛使用的角位置测量系统,大量应用于高精度及大中型数控系统、机器人控制、工业控制、武器火力控制及惯性导航领域中。 传统的角测量系统面临的问题有:体积、重量、功耗偏大,调试、误差补偿试验复杂,费用较高。本文从微型化、智能化的方向进行研究,是解决传统角测量系统所面临问题的好途径。 本文所研究的旋转变压器---数字转换器是由信号调理模块、系统芯片C8051F064和输出控制模块组成的。整个系统的三路输入信号为X=AsinOcosar、Y=Acosθcos ot和Z=Ucosar(基准信号),输出信号为偏转角θ,输出形式为16 位数字量。信号调理模块是由模拟电路组成的,包括信号输入电路、相敏整流电路、滤波电路和直流稳压电源电路,其难点在于相敏整流电路的设计。信号调理模块的主要功能是把输入的交流信号X=AsinOcosor、Y=Acosθcosot转变成直流信号Bsinθ和Bcosθ,并使输出的直流信号在0~2.4V之间;系统芯片C8051F064是CYGNAL公司近年来推出的一款功能齐全的完全集成的混合信号片上系统型单片机。在本文所设计的系统中,系统芯片的输入信号为直流信号Bsinθ和Bcosθ,通过片内自带的2个16位A/D转换器对输入信号的数据进行采样和转换,并对转换完的数据进行滤波处理,以减小由于外界干扰而产生的误差,再用除法和反正切函数解算出偏转角θ的16位数字量;输出控制模块主要完成的功能是通过UARTO向计算机实时发送由单片机计算出来的偏转角度0的16位数字量,而串口的RS-232电平与单片机系统采用的是TTL电平之间的转换所采用的转换芯片是MC1488和MC1489。
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct{ char name[20]; // 学生姓名 int id; // 学生学号 char sex; // 学生性别 int age; // 学生年龄 float height; // 学生身高 float weight; // 学生体重 }Student; typedef struct{ Student *data; // 存储学生记录的数组 int front; // 队列头指针,指向队列中第一个元素的位置 int rear; // 队列尾指针,指向队列中最后一个元素的位置的下一个位置 int size; // 队列中元素的数量 int capacity; // 队列的最大容量,即数组 data 的长度 }Queue; // 初始化队列 void initQueue(Queue *q, int capacity){ q->data = (Student*)malloc(sizeof(Student)*capacity); q->front = q->rear = q->size = 0; q->capacity = capacity; } // 入队操作 void enqueue(Queue *q, Student stu){ if(q->size == q->capacity){ // 队列已满 printf("队列已满,无法入队!\n"); return; } q->data[q->rear] = stu; // 将学生记录存入队列 q->rear = (q->rear + 1) % q->capacity; // 将队尾指针向后移动一位,循环使用数组空间 q->size++; // 队列中元素数量加 1 } // 出队操作,返回被删除的学生记录 Student dequeue(Queue *q){ if(q->size == 0){ // 队列为空 printf("队列为空,无法出队!\n"); Student stu_null = {"", 0, '\0', 0, 0.0, 0.0}; return stu_null; } Student stu = q->data[q->front]; // 将队头元素存入变量 stu q->front = (q->front + 1) % q->capacity; // 将队头指针向后移动一位,循环使用数组空间 q->size--; // 队列中元素数量减 1 return stu; // 返回被删除的学生记录 } // 清空队列 void clearQueue(Queue *q){ free(q->data); q->front = q->rear = q->size = 0; } // 判断队列是否为空 int isEmpty(Queue *q){ return (q->size == 0) ? 1 : 0; } // 判断队列是否已满 int isFull(Queue *q){ return (q->size == q->capacity) ? 1 : 0; } int main(){ Queue q; // 定义一个队列 initQueue(&q, 10); // 初始化队列,设置队列的最大容量为 10 // 测试入队操作 Student stu1 = {"张三", 1001, 'M', 20, 175.0, 65.0}; enqueue(&q, stu1); Student stu2 = {"李四", 1002, 'F', 21, 160.0, 50.0}; enqueue(&q, stu2); Student stu3 = {"王五", 1003, 'M', 22, 180.0, 70.0}; enqueue(&q, stu3); // 测试出队操作 Student stu = dequeue(&q); printf("出队学生记录:\n"); printf("姓名:%s,学号:%d,性别:%c,年龄:%d,身高:%.1f,体重:%.1f\n", stu.name, stu.id, stu.sex, stu.age, stu.height, stu.weight); // 测试清空队列操作 clearQueue(&q); // 测试队列是否为空和队列是否已满的功能 printf("队列是否为空:%d\n", isEmpty(&q)); printf("队列是否已满:%d\n", isFull(&q)); return 0; }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值