一个表内的两列有依赖关系,具体如图所示,我想知道SQL语句怎么写,新手求大神帮帮忙啊 20C

![图片说明](https://img-ask.csdn.net/upload/201609/10/1473501134_973620.png)图片说明

1个回答

图片说明再补充一张图片说明

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
这个语句的两个括号的位置为什么是在这里?
一个比较简单的程序(来源Cprimerplus P197 程序7.8) /* paint.c -- 使用条件运算符 */ #include<stdio.h> #define COVERAGE 350//每罐油漆可刷的面积(单位:平方英尺) int main() { int sq_feet; int cans; printf("Enter number of square feet to be painted:\n"); while(scanf("%d",&sq_feet)==1) { cans=sq_feet/COVERAGE; cans+=((sq_feet%COVERAGE==0))?0:1;//这一行的括号 printf("You need %d %s of paint.\n",cans,cans==1?"can":"cans"); printf("Enter next value (q to quit):\n"); } return 0; } 问题: 在cans+=((sq_feet%COVERAGE==0))?0:1;这一行, 为什么这两个括号是在这里的,因为我自己写的是 cans+=((sq_feet%COVERAGE)==0)?0:1; 这两种写法对结果是没有影响的,但是括号位置不一样可能意味着逻辑思维不一样,我想问清楚这个问题,以免以后秉着错误的思维写更大的程序。
线性表结构的实现,内心迷乱,希望能得到帮助
#include<stdio.h> #include <stdlib.h> #define ERROR 0 #define OK 1 typedef int Status; typedef int Elemtype; typedef struct node { Elemtype elem[LIST_SIZE]; int length; }Sqlist; typedef int Elemtype; typedef int Status; typedef struct LNode{ Elemtype data; struct LNode *next; }LNode,*Linklist; Status LengthList(Linklist *L); Status create(Sqlist *L,int n); Status Findlen1(Sqlist *L); Elemtype GetElem(Sqlist *L, int n); int LocateElem(Sqlist *L, int n); Status ListInsert_Sq(Sqlist *L,int i,int x); Status LisDele_Sq(Sqlist *L,int i); int Printlist(Sqlist* L); Status Init_linklist(Linklist *L); void Creat_Linklist(Linklist *L,int n); Status LengthList(Linklist *L); Status Get_Linklist(Linklist *L,int i,Elemtype *e); Status Locate_Linklist(Linklist *L,Elemtype e); Status Insert_Linklist(Linklist *L,int i,Elemtype e); Status Delete_Linklist(Linklist *L,int i,Elemtype *e) ; void Display(Linklist *L) ; void menu1(); void menu2(); int main() { int x; while(1) { system("cls"); printf("\n\n\n\n\n\n\n\n"); printf("\t\t\t\t\t1:顺序表\n"); printf("\t\t\t\t\t2:链表\n"); printf("\t\t\t\t\t3:退出\n"); printf("\n\t\t\t\t\t请输入您的选择(1-3)=:"); scanf("%d",&x); switch(x) { case 1:menu1(); break; case 2:menu2(); break; case 3:return 0;break; default:printf("error");return 1; break; } printf("\n"); system("pause"); } return 0; } Status create(Sqlist *L, int n) { int i; if(n>LIST_SIZE) return ERROR; for(i=0;i<n;i++) { printf("请输入第%d个数据的值:", i+1); scanf("%d", &L->elem[i]); } L->length=n; return OK; } Status Findlen1(Sqlist *L) {return (L->length);} Elemtype GetElem(Sqlist *L, int n) { { if (n<1 || n>L->length) { return ERROR; } return L->elem[n - 1]; } } int LocateElem(Sqlist *L, int n) //4 {int i; for(i=0;i<=L->length;i++) if(L->elem[i]==n) return i+1; else return 0; } Status ListInsert_Sq(Sqlist *L,int i,int x) //5 {int j; if (i<1||i>L->length +1) return ERROR; if(L->length>100) return ERROR; for(j=L->length-1;j>=i-1;j--) L->elem[j+1]=L->elem[j]; L->elem[i-1]=x; ++(L->length); return OK; } Status LisDele_Sq(Sqlist *L,int i) //6 {int j; if ((i<1)||(i>L->length)) return ERROR; for(j=i;j<=L->length-1;j++) L->elem[j-1]=L->elem[j]; --L->length; return OK; } int Printlist(Sqlist* L) //7 { int j; for (j = 0; j <= L->length - 1; j++) { printf("第%d个数据为%d\n", j + 1, L->elem[j]); } return OK; } Status Init_linklist(Linklist *L) { *L=(Linklist)malloc(sizeof(LNode)); if(!(*L)) { return ERROR; } (*L)->next=NULL; return OK; } void Creat_Linklist(Linklist *L,int n) { Linklist p,q; int i; p = *L; for(i=0;i<n;i++) { printf("请输入链表第%d个元素:",i); q=(Linklist)malloc(sizeof(LNode)); scanf("%d",&q->data); p->next=q; p=q; } p->next=NULL; } Status LengthList(Linklist *L) { int i=0; Linklist p,q; p = *L; if(p->next==NULL) return ERROR; while(p->next!=NULL) { i++; p=p->next; } return i; } Status Get_Linklist(Linklist *L,int i,Elemtype *e) { int j=1; Linklist p,q; p = *L; if(i<1||!p->next||i>LengthList(L)) { return ERROR; } while(j<=i&&p) { p=p->next; j++; } if(j-1==i) { *e=p->data; return OK; } else return ERROR; } Status Locate_Linklist(Linklist *L,Elemtype e) { int i=1; Linklist p,q; p = (*L)->next; while(p->data!=e&&p) { p=p->next; i++; } if(p->data!=e) return -1; else return i; } Status Insert_Linklist(Linklist *L,int i,Elemtype e) { int j=1; Linklist p,q; p = *L; if(i<1||!p->next||i>LengthList(L)) { return ERROR; } while(p&&j<i) { p=p->next; j++; } q=(Linklist)malloc(sizeof(LNode)); q->data=e; q->next=p->next; p->next=q; return OK; } Status Delete_Linklist(Linklist *L,int i,Elemtype *e) { int j=1; Linklist p,q; p = *L; if(i<1||!p->next||i>LengthList(L)) { return ERROR; } while(j<i&&p->next) { p=p->next; j++; } q=p->next; *e=q->data; p->next=q->next; free(q); return OK; } void Display(Linklist *L) { LNode *p; p=(*L)->next; while(p) { printf("%d ",p->data); p=p->next; } printf("\n"); } menu1() { int y,n; Sqlist L; Status T; while(1) { system("cls"); printf("\n\n\n\n\n\n\n\n"); printf("\t\t\t\t\t1:创建顺序线性表\n"); printf("\t\t\t\t\t2:求顺序线性表的长度\n"); printf("\t\t\t\t\t3:按序号取顺序表元素\n"); printf("\t\t\t\t\t4:按值查找顺序表\n"); printf("\t\t\t\t\t5:插入元素\n"); printf("\t\t\t\t\t6:删除元素\n"); printf("\t\t\t\t\t7:输出顺序线性表\n"); printf("\t\t\t\t\t8:返回\n"); printf("\t\t\t\t\t\t请输入您的选择(1-8)=:"); scanf("%d",&y); if(y==8) break; switch(y) { case 1: system("cls"); printf("请输入你要创建的线性表的长度:"); scanf("%d",&n); T=create(&L,n); if(T==ERROR) printf("创建失败,线性表长度超限!!"); else printf("创建线性表成功!!"); system("pause"); break; case 2:system("cls"); Status a; a=Findlen1(&L); printf("您所建线性表长度为%d\n",n); system("pause"); break; case 3:system("cls"); int b; printf("请输入你想找的数据的序号: "); scanf("%d", &n); b = GetElem(&L, n); printf("该序号的数据为%d\n", b); system("pause"); break; case 4:system("cls"); printf("请输入你想找的值:"); scanf("%d", &n); b=LocateElem(&L,n); if (b == 0) printf("线性表中没有该值\n"); else printf("该值在线性表中的第%d位\n", b); system("pause"); break; case 5:system("cls"); int C;int x; printf("请输入你想在哪一个元素前面插入:"); scanf("%d",&n); printf("请输入你想插入的数据:"); scanf("%d",&x); C= ListInsert_Sq(&L,n,x); if(C==1) printf("插入成功"); else printf("插入失败"); system("pause"); break; case 6:printf("请输入您想删除的数字:"); scanf("%d",&n); C=LisDele_Sq(&L,n); if(C==1) printf("删除成功"); else printf("删除失败"); system("pause");break; case 7:system("cls"); Printlist(&L); system("pause"); break; default:printf("error"); break; } printf("\n"); system("pause"); } return 1; } menu2(){ int z; while(1) { system("cls"); printf("\n\n\n\n\n\n\n\n"); printf("\t\t\t\t\t1:创建链式线性表\n"); printf("\t\t\t\t\t2:求链式线性表的长度\n"); printf("\t\t\t\t\t3:按序号取链表元素\n"); printf("\t\t\t\t\t4:按序号取链表元素\n"); printf("\t\t\t\t\t5:插入元素\n"); printf("\t\t\t\t\t6:删除元素\n"); printf("\t\t\t\t\t7:输出链式线性表\n"); printf("\t\t\t\t\t8:返回\n"); printf("\t\t\t\t\t\t请输入您的选择(1-8)=:"); scanf("%d",&z); if(z==8) break; switch(z) { case 1: printf("这里是创建链式线性表"); int n,num,e,value; Linklist L; value=Init_linklist(&L); if(value) printf("单链表初始化成功!\n"); else return ERROR; printf("请输入单链表的长度:") ; scanf("%d",&n); Creat_Linklist(&L,n); printf("单链表中各元素的值为:"); Display(&L);break; case 2:printf("这里是求链式线性表的长度"); break; case 3: int n,num,e,value; printf("这里是按值取链表元素"); printf("\n\n请输入要查找的值e= "); scanf("%d",&num); value=Locate_Linklist(&L,num); if(value>0) printf("该元素在线性表的位序位:%d",value); else printf("\n无该值,查找失败!"); break; case 4: int n,num,e,value; printf("这里是按序号取链表元素"); printf("\n\n请输入要查找的位置:"); scanf("%d",&n); value=Get_Linklist(&L,n,&e); if(value) printf("单链表中第%d位的值为%d",n,e); else printf("\nerror!") ; break; case 5: int n,num,e,value; printf("这里是插入元素"); printf("\n请输入插入的位置:"); scanf("%d",&n); printf("请输入插入的元素:"); scanf("%d",&num); Insert_Linklist(&L,n,num); printf("进行插入操作后\n单链表中各元素的值为:"); Display(&L);break; case 6: int n,num,e,value; printf("这里是删除元素"); printf("\n\n请输入删除的位置:"); scanf("%d",&n); Delete_Linklist(&L,n,&e); printf("被删除元素的值为:%d",e); printf("\n进行删除操作后\n单链表中各元素的值为:"); Display(&L); break; case 7:printf("这里是输出链式线性表"); printf("单链表中各元素的值为:"); Display(&L);break; default:printf("error"); break;} printf("\n"); system("pause"); return 1; } }
当sql语句中从两表中查询的两列模糊时,如何处理
``` string wax = comboBox1.Text + comboBox2.Text + comboBox3.Text;string s=comboBox1.Text+comboBox2.Text+comboBox3.Text; SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select " + wax + ",para," + s + " from 电缆参数,电缆参数1", m); chart2.Series[0].YValueMembers = wax;chart2.Series[1].YValueMembers = s; ``` 两组数(wax,s)都需要根据下拉框的值来选择列,启动时显示ambiguous column name: CHR111009(comboBox1.Text=CHR1,comboBox2.Text=1,c omboBox3.Text=1009) 也试过 ``` SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select " + wax + ",para from 电缆参数 union select " + s + ",para from 电缆参数1 ", m); ``` 显示 union前后所取得列数应一样 也试过 ``` string dbPath = @"D:\历年高考分数.db"; string sq = @"Data Source=" + dbPath; m = new SQLiteConnection(sq); m.Open(); SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select " + wax + ",para from 电缆参数", m); SQLiteDataAdapter mAdapter1 = new SQLiteDataAdapter("select " + s + " from 电缆参数1", m); DataSet ds = new DataSet(); DataSet ds1 = new DataSet(); mAdapter.Fill(ds); mAdapter1.Fill(ds1); DataTable dt = ds.Tables[0]; DataTable dt1 = ds1.Tables[0]; //设置图表的数据源 chart2.DataSource = dt; //chart2.DataSource = dt1+dt; chart2.DataSource = dt1; ``` 启动时会显示找不到名为“para”的列。但表中有“para”列,可能 chart2.DataSource以最后出现的dt1为准。可不可以让wax,s分别是同一列的前20个数,后20个数 如果不行,应该怎么改
数据库中有x,y两列数,在sql中如何进行加减乘除
问题一:数据库中只有x,y两列数,我下面这样写可以取到z,w两组数吗 要用到乘方直接用^可以吗 ``` string sq = @"Data Source=" + dbPath; m = new SQLiteConnection(sq); m.Open(); SQLiteDataAdapter mAdapter = new SQLiteDataAdapter = ("select x,y,x*y as z from 特性", m); DataSet ds = new DataSet(); mAdapter.Fill(ds); DataTable dt = ds.Tables[0]; ``` 能不能SQLiteDataAdapter mAdapter = new SQLiteDataAdapter = ("select x,y,x*y as z from 特性", m);处直接SQLiteDataAdapter mAdapter = new SQLiteDataAdapter = ("select x*y as z from 特性", m);吗
数据库中有x,y两列数,在sql中如何进行加减乘除乘方
问题一:数据库中只有x,y两列数,我下面这样写可以取到z,w两组数吗 要用到乘方直接用^可以吗 问题二:另外我在数据库中只给x五个数(0,120,240,360,480),如何让x可取0-480中任何一数 ``` string dbPath = @"D:\历年高考分数.db"; string sq = @"Data Source=" + dbPath; m = new SQLiteConnection(sq); m.Open(); SQLiteDataAdapter mAdapter = new SQLiteDataAdapter = ("select z,w from 特性 where z=0.05x^2+x+86.66 and w=x*y", m); DataSet ds = new DataSet(); mAdapter.Fill(ds); DataTable dt = ds.Tables[0]; ```
java 异常调用的问题 无法得到正确的答案
``` import java.util.Scanner; class InvalidSideException extends Exception{ InvalidSideException(String s){ super(s); } } class Square{ int sl; public Square(int sl) throws InvalidSideException{ if (sl <= 0){ throw new InvalidSideException("Side length must be greater than 0"); }else{ this.sl = sl; } } public int getArea(){ return this.sl * this.sl; } } public class Driver{ public static void main(String[] args){ System.out.print("Enter side length of square:"); Scanner s = new Scanner(System.in); int x = s.nextInt(); try{ Square sq = new Square(x); System.out.println(sq.getArea()); }catch(InvalidSideException e){ e.printStackTrace(); } } } ``` 我想得到 Enter·side·length·of·square:0 Enter◦side◦length◦of◦square:Side◦length◦must◦be◦greater◦than◦0. 但是 结果总是 Enter◦side◦length◦of◦square: 无法打印Side◦length◦must◦be◦greater◦than◦0. 求问怎么diao'yong
一个用户注册的统计的sq查询
SELECT CONVERT(CHAR(10),AddTime,120) as 注册时间, COUNT(-1) as 递增数 ,(select count(-1) from UserInfo where AddTime<=U.AddTime) as 总数 FROM UserInfo as U GROUP BY CONVERT(CHAR(10),AddTime,120),U.AddTime order by CONVERT(CHAR(10),AddTime,120) desc ======================以上为SQL语句 表结构如下: SELECT Id, AddTime FROM UserInfo 想要实现的为: ![图片说明](https://img-ask.csdn.net/upload/201504/27/1430105978_771065.png) 但测试站上执行的为: ![图片说明](https://img-ask.csdn.net/upload/201504/27/1430106005_313682.jpg) 测试站为SQL2008+的版本,本地为2005 所以请帮忙,看看 怎样的SQL好一些。
求救帮忙看一下我这个用C语言写的顺序线性表线性表合并为什么会有warning C4020: ?一直找不到原因
调试环境VC6.0 ``` #include<stdlib.h> #include<stdio.h> typedef int Status; // Status 是函数返回值类型,其值是函数结果状态代码。 #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define List_Init_Size 100 //线性表存储空间初始分配量 #define Listincerment 10 //线性表存储空间的分配增量 typedef struct SqList { int *elem; int length; int listsize; //当前分配的存储容量() }SqList; Status InitList_Sq(SqList*L) {//初始化顺序线性表// L->elem=(int*)malloc(List_Init_Size*sizeof(int)); if(!L->elem)exit(OVERFLOW); //存储分配失败 L->length=0; return OK; } Status GetElem(SqList a,int i,int*e) { //读取元素 if(i<0||i>a.length) return ERROR; e=&a.elem[i-1]; //i-1存储第i个元素 return OK; } int ListLength(SqList L) { //计算长度 if(!L.elem)exit(ERROR); return L.length; } Status ListInsert_Sq(SqList *L, int i, int e) { //i位置之前插入新元素e if(i<1||i>L->length+1)return ERROR; if((L->length)>=(L->listsize)){ //当前存储空间已满,增加分配 int*newbase,*q,*p; newbase=(int*)realloc(L->elem,(L->listsize+Listincerment)*sizeof(int)); if(!newbase)exit(OVERFLOW);//存储分配失败} L->elem=newbase; //新的基址 L->listsize+=Listincerment; //增加容器容量 q=&(L->elem[i-1]); //q为插入位置 for(p=&(L->elem[L->length-1]);p>=q;--p) *(p+1)=*p; //插入位置及以后的元素后移 *q=e; //插入e ++L->length; } return OK;} void MergeList(SqList La,SqList Lb,SqList*Lc) { //线性表La和Lb中的数据元素按照值非递减排列。 int i,j,k,ai,bj; InitList_Sq(Lc); i=j=1;k=0; La.length=ListLength(La); Lb.length=ListLength(Lb); while((i<=La.length)&&(j<=Lb.length)) { GetElem(La,i,&ai); GetElem(Lb,j,&bj); if(ai<=bj) { ListInsert_Sq(Lc,++k,ai); ++i;} else{ListInsert_Sq(Lc,++k,bj);++j;} } while(i<=La.length) { GetElem(La,i,&ai); i++; ++k; InitList_Sq(Lc,k,&ai);} while(j<=Lb.length) { GetElem(Lb,j,&bj);j++; ++k; InitList_Sq(Lc,k,&bj); } } void output(SqList L) { int i; for(i=0;i<L.length;i++) { printf("%d ",L.elem[i]); } } void main() { SqList a,b,c; int i,j,k; InitList_Sq(&a); InitList_Sq(&b); printf("输入要写入链表a中元素的个数"); scanf("%d",&j); printf("输入每个元素"); for(i=1;i<=j;i++) { int e; scanf("%d",&e); ListInsert_Sq(&a,i,e); } printf("输入要写入链表b中元素的个数\n"); scanf("%d",&k); printf("输入每个元素"); for(j=1;j<=k;i++) { int e; scanf("%d",&e); ListInsert_Sq(&b,i,e); } MergeList(a,b,&c); output(c); } ``` ![图片说明](https://img-ask.csdn.net/upload/201912/02/1575268330_217932.png)
请问为什么我写的C语言中顺序存储的线性表的输出有这个错误
调试环境VC6.0 ``` #include<stdlib.h> #include<stdio.h> typedef int Status; // Status 是函数返回值类型,其值是函数结果状态代码。 #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define List_Init_Size 100 //线性表存储空间初始分配量 #define Listincerment 10 //线性表存储空间的分配增量 typedef struct SqList { int *elem; int length; int listsize; //当前分配的存储容量() }SqList; Status InitList_Sq(SqList*L) {//初始化顺序线性表// L->elem=(int*)malloc(List_Init_Size*sizeof(int)); if(!L->elem)exit(OVERFLOW); //存储分配失败 L->length=0; return OK; } Status ListInsert_Sq(SqList *L, int i, int e) { //i位置之前插入新元素e if(i<1||i>L->length+1)return ERROR; if((L->length)>=(L->listsize)){ //当前存储空间已满,增加分配 int*newbase,*q,*p; newbase=(int*)realloc(L->elem,(L->listsize+Listincerment)*sizeof(int)); if(!newbase)exit(OVERFLOW);//存储分配失败} L->elem=newbase; //新的基址 L->listsize+=Listincerment; //增加容器容量 q=&(L->elem[i-1]); //q为插入位置 for(p=&(L->elem[L->length-1]);p>=q;--p) *(p+1)=*p; //插入位置及以后的元素后移 *q=e; //插入e ++L->length; } return OK;} void output(SqList L) { int i; for(i=0;i<L.length;i++) { printf("%d ",&L.elem[i]); } } void main() { SqList a; int i,j; InitList_Sq(&a); printf("输入要写入链表a中元素的个数"); scanf("%d",&j); printf("输入每个元素"); for(i=1;i<=j;i++) //小于等于 { int e; scanf("%d",&e); ListInsert_Sq(&a,i,e); } output(a); } ``` ![图片说明](https://img-ask.csdn.net/upload/201912/02/1575260361_988221.png)
内部排序的性能分析:函数调用的问题?在主函数中用一种方法排序后,排好序的顺序表被带回主函数,再用另一种方法排序等于没用了
原先用的void insertsort(Sqlist &L),改成void insertsort(Sqlist L)还是不行,形参不是传值调用主函数不会改变嚒? 已经测试排序的代码没有问题,单独使用一种方法没有问题,几种同时使用才会出问题, ![图片说明](https://img-ask.csdn.net/upload/201912/09/1575891779_129272.png) 第一行:随机生成的顺序表 第二行:Insert排序后的顺序表 第三行:比较次数,移动次数 第四行:Shell排序前的顺序表 第五行:Shell排序后的顺序表 可以看出shell根本不需要排序,移动次数为0...... 代码太长截取一部分有用的: ``` #define _CRT_SECURE_NO_DEPRECATE #include<stdio.h> #include<stdlib.h> #include<time.h> typedef int Position; typedef int ElemType; typedef int Status; int compare1=0,compare2=0,compare3=0,compare4=0,compare5=0,compare6=0;//比较次数 int move1 = 0, move2 = 0, move3 = 0, move4 = 0, move5 = 0, move6 = 0;//移动次数 ElemType*p, *q; #define LIST_INIT_SIZE 100 #define LISTINCREMENT 10 #define OK 1; #define TRUE 1; #define FALSE 0; #define ERROR 0; #define OVERFLOW -2; /*①SqList.h线性表的动态分配顺序存储结构*/ typedef struct { int key; }lkey; typedef struct { lkey *elem; int length; int listsize; }SqList; /*②顺序表基本操作接口定义*/ //操作结果:构造一个空的线性表 Status InitList_Sq(SqList &L); //操作结果:在L中第i个元素之前插入新的元素e,L的长度加1 Status ListInsert_Sq(SqList &L, int i, ElemType e); //操作结果:依次对L的每个数据元素调用(*visit)(),一旦(*visit)()失败,则操作失败 Status ListTraverse_Sq(SqList L, Status(*visit)(ElemType)); //将元素e的值打印出来 Status visit_sp(ElemType e); //直接插入排序 void InsertSort(SqList L); //希尔排序 void ShellSort(SqList L, int dlta[], int t); void Shell(SqList L, int dk);//一趟希尔插入排序 //起泡排序 void BubbleSort(SqList L); //快速排序 void QuickSort(SqList L); void Quick(SqList L, int low, int high); int QsortPartion(SqList L, int low, int high);//一趟快速排序 //简单选择排序 void SelectSort(SqList L); //堆排序 void HeapSort(SqList L); void HeapAdjust(SqList L, int s, int m);//建大顶堆函数 //随机生成数构造线性表 Status InitList_Sq(SqList &L) { int i; L.elem = (lkey*)malloc(LIST_INIT_SIZE * sizeof(lkey)); if (!L.elem)exit(-2); L.length = 0; L.listsize = LIST_INIT_SIZE; //srand((unsigned)time(NULL)); for (i = 1; i < 15; i++) { L.elem[i].key = rand() % 100 + 1; ListInsert_Sq(L, i, L.elem[i].key); } return OK; /*请参考课本上的算法2.3*/ } //在L中第i个元素之前插入新的元素e,L的长度加1 Status ListInsert_Sq(SqList &L, int i, ElemType e) { if (i<1 || i>L.length + 1) return ERROR; if (L.length >= L.listsize) { lkey*newbase = (lkey*)realloc(L.elem, (L.listsize + LISTINCREMENT) * sizeof(lkey)); if (!newbase)return ERROR; L.elem = newbase; L.listsize += LISTINCREMENT; } q = &(L.elem[i - 1].key); for (p = &(L.elem[L.length - 1].key); p >= q; --p) *(p + 1) = *p; *q = e; ++L.length; return OK; /*请参考课本上的算法2.4*/ } //操作结果:依次对L的每个数据元素调用(*visit)(),一旦(*visit)()失败,则操作失败 Status ListTraverse_Sq(SqList L, Status(*visit)(ElemType)) { int i; for (i = 1; i <= L.length; i++) (*visit)(L.elem[i - 1].key); printf("\n"); return OK; } //将元素e的值打印出来 Status visit_sp(ElemType e) { printf("%d ", e); return OK; } //直接插入排序 void InsertSort(SqList L) { int compare1 = 0, move1 = 0; int i=0, j=0; lkey rc; for (i = 1; i<L.length; ++i)//从第二个开始 { compare1++; if (L.elem[i].key < L.elem[i - 1].key) { move1 += 2; rc = L.elem[i]; L.elem[i] = L.elem[i - 1]; for (j = i - 2; j >= 0 && rc.key < L.elem[j].key; --j)//从i-2个开始 { compare1++; L.elem[j + 1] = L.elem[j]; move1++; } L.elem[j + 1] = rc; move1 += 3; } } ListTraverse_Sq(L,visit_sp); printf("%d %d\n", compare1, move1); } //希尔排序 void ShellSort(SqList L, int dlta[], int t) { ListTraverse_Sq(L, visit_sp); int k; for (k = 0; k < t; k++) Shell(L, dlta[k]); ListTraverse_Sq(L, visit_sp); printf("%d %d\n", compare2, move2); } void Shell(SqList L, int dk)//一趟希尔插入排序 { lkey rc; int j; for (int i = dk; i < L.length; i++) { compare2++; if (L.elem[i].key < L.elem[i - dk].key)//比较i和i-dk { rc = L.elem[i]; move2++; for (j = i - dk; j >= 0 && (rc.key < L.elem[j].key); j -= dk)//[6]和[3],[0]比较 { compare2++; L.elem[j + dk] = L.elem[j];//记录后移,查找插入位置 move2++; } L.elem[j + dk] = rc;//插入 move2++; } } } int main() { SqList L; int i; int dita[3] = { 5,3,1 }, t = 3; for (i = 0; i <= 5; i++) { printf("当前随机数为:\n"); InitList_Sq(L); ListTraverse_Sq(L, visit_sp); InsertSort(L); ShellSort(L, dita, t); //BubbleSort(L); //QuickSort(L); //SelectSort(L); //HeapSort(L); /*printf("------|-比较次数-||-移动次数-|\n"); printf("Insert| %d || %d |\n", compare1, move1); printf("Shell | %d || %d |\n", compare2, move2); printf("Bubble| %d || %d |\n", compare3, move3); printf("Quick | %d || %d |\n", compare4, move4); printf("Select| %d || %d |\n", compare5, move5); printf("Heap | %d || %d |\n", compare6, move6);*/ } system("pause"); return 0; } ```
数据结构中函数传值问题
在C++数据结构中有这样的一段代码 ``` typedef int ElemType; typedef struct { int stacksize; ElemType *base;//Top和base都是来存取栈的位置 区索引作用 ElemType *top; }sqStack; //创建stack void sq_Init(sqStack *s) { s->base = (ElemType*)malloc(Stack_Init_Size*sizeof(ElemType)); if(!s->base) exit(0); s->top = s->base; s->stacksize = Stack_Init_Size; } ``` 那在我需要调用sq_Init函数的时候,应该怎样传值。 是 ``` int main() { sqStack s; sq_Init(&s); return 0; } ``` 还是 ``` int main() { sqStack *s; sq_Init(s); return 0; } ``` 为什么呢?提前谢谢大家了!
C#winform打包时,在自己电脑可以用,在别人的电脑上数据库出问题了,如何解决
我当时写程序时,直接把.db文件发在了D盘(string dbPath = @"D:\历年高考分数.db";string sq = @"Data Source=" + dbPath;),我默认打包的软件的安装路径为D:\温度4,下面两张图是application files那步的添加的文件以及其中数据库添加的文件。 C#winform打包时,在自己电脑可以用,以.exe的文件格式发给别人,在另一个人的电脑不可用(如下图),提示没有表2(数据库中有表2),但是制作安装包时,数据库也打包到一起了。 在他的电脑上我发现D:\温度4中的.db文件内存是148KB,而在D:\上也生成了一个.db文件,不过它的内存为0KB,另外在他的电脑上好像用ANSYS识别的.db。 我想问下到底是他的识别软件的问题,还是application files那步的添加的文件有问题,还是我的数据连接的路径有问题 ![图片说明](https://img-ask.csdn.net/upload/201909/18/1568777849_846512.png) ![图片说明](https://img-ask.csdn.net/upload/201909/18/1568777829_507694.png) ![图片说明](https://img-ask.csdn.net/upload/201909/18/1568777898_845962.png) ![图片说明](https://img-ask.csdn.net/upload/201909/18/1568777944_382780.png) ![图片说明](https://img-ask.csdn.net/upload/201909/18/1568777975_775651.png)
有没有sql数据库技术实现以下内容,即如何使三个下拉框选好后,gzl列根据选的值取代对应的列
``` string dbPath = @"D:\历年高考分数.db"; string sq = @"Data Source=" + dbPath; m = new SQLiteConnection(sq); m.Open(); SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select yxlc,gzl from 曲线三 where gzl=('a'+'b'+'c')",m); //SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select yxlc,gzl from 曲线三 where gzl=(a+b+c)", m); //SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select yxlc,gzl from 曲线三 where gzl=abc", m); //SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select yxlc,gzl from 曲线三 where gzl=a-b-c", m); DataSet ds = new DataSet(); mAdapter.Fill(ds); DataTable dt = ds.Tables[0]; //设置图表的数据源 chart1.DataSource = dt; chart1.Series[0].IsVisibleInLegend = false;//是否显示图例 chart1.Series["Series1"].ChartType = SeriesChartType.Spline;//形状 chart1.Series[0].XValueMember = "yxlc";//X轴数据成员列 chart1.Series[0].YValueMembers = "gzl";//Y轴数据成员列 chart1.DataBind(); chart1.BringToFront(); m.Close(); ``` 令a=combox1.text,b=combox2.text,c=combox1.text, X值取yxlc列。a=CHR1,b=拖车1位,c=1002时,y取CHR111002列;a=CHR1,b=拖车1位,c=1009时,y取CHR111009列;a=CHR1,b=拖车2位,c=1009时,y取CHR121009列;等等(一共125列) 即如何使三个下拉框选好后,gzl列根据选的值取代对应的列 ![图片说明](https://img-ask.csdn.net/upload/201908/10/1565444988_903201.png)![图片说明](https://img-ask.csdn.net/upload/201908/10/1565445025_673281.png)
两个线性表合并,去掉两个相同元素,输出-842150451
![图片说明](https://img-ask.csdn.net/upload/201710/20/1508513508_858742.png) #include<iostream> using namespace std; typedef struct //定义顺序表 { int *elem; int length; }SqList; void InitList_Sq(SqList &L,int n) //创建顺序表 { L.elem=new int[n]; if(!L.elem) exit(0); L.length=0; } void input(SqList &L,int n) //依次往顺序表L里输入数据 { int i; cout<<"请输入该表的元素(按非递减的顺序):"; for(i=0;i<n;i++) { cin>>L.elem[i]; L.length++; } } void output(SqList L) //依次输出顺序表里的每个元素 { int i; for(i=0;i<L.length;i++) { if(i) cout<<","; cout<<L.elem[i]; } } void MergeList_Sq(SqList LA,SqList LB,SqList &LC) //算法2.15 顺序有序表的合并 { //已知顺序有序表LA和LB的元素按值非递减排列 //归并LA和LB得到新的顺序有序表LC,LC的元素也按值非递减排列 int *pa,*pb,*pc,*pa_last,*pb_last; pa=LA.elem;pb=LB.elem; //指针pa和pb的初值分别指向两个表的第一次元素 LC.length=LA.length+LB.length; //新表长度为待合并两表的长度之和 LC.elem=new int[LC.length]; //为合并后的新表分配一个数组空间 pc=LC.elem; //指针pc指向新表的第一个元素 pa_last=LA.elem+LA.length-1; //指针pa_last指向LA表的最后一个元素 pb_last=LB.elem+LB.length-1; //指针pb_last指向LB表的最后一个元素 while(pa<=pa_last && pb<=pb_last) //两个表都非空 { if(*pa>*pb) { //依次“摘取”两表中值较小的结点插入到LC表的最后 *pc++=*pa++; } else if(*pa==*pb) { *pc++=*pa++; //*pb++; } else *pc++=*pb++; } while(pa<=pa_last) //LB已到达表尾,依次将LA的剩余元素插入LC表的最后 *pc++=*pa++; while(pb<=pb_last) //LA已到达表尾,依次将LB的剩余元素插入LC表的最后 *pc++=*pb++; } //MergeList_List int main() { SqList La,Lb,Lc; int num_a,num_b; cout<<"请输入非递减线性表a的个数n:"; cin>>num_a; InitList_Sq(La,num_a); //La表的创建 input(La,num_a); //依次往顺序表La里输入数据 cout<<"请输入非递减线性表b的个数n:"; cin>>num_b; InitList_Sq(Lb,num_b); //Lb表的创建 input(Lb,num_b); //依次往顺序表La里输入数据 MergeList_Sq(La,Lb,Lc); //将顺序表La和Lb进行合并 cout<<"非递减线性表a,b合并后的非递减线性表c为:\n"; //输出合并后的有序顺序表Lc output(Lc); cout<<endl; return 0; }
存储过程执行效率很低,半天查询不到结果,如何优化,缩短查询时间
create or replace PACKAGE BODY YQSBJKXX IS procedure P_YQGL_JMJKXX(p_cur out sys_refcursor,p_fw number,p_sj date) iS /* CREATE GLOBAL TEMPORARY TABLE "TMP_YQDT_JMJKXXB" ( jmid INTEGER,--居民id sq INTEGER,--社区 xq INTEGER,--小区 ld INTEGER,--楼栋 mp INTEGER,--门牌 xm VARCHAR2(100), --姓名 sfzh VARCHAR2(100), --身份证号 sjh VARCHAR2(100),--手机号 zao_a VARCHAR2(30),--早 zhong_a VARCHAR2(30),--中 wan_a VARCHAR2(30),--晚 sffr VARCHAR2(100), --发热 sfks VARCHAR2(100), --咳嗽 sfot VARCHAR2(100), --呕吐 sffl VARCHAR2(100), --乏力 yczz VARCHAR2(100), --异常 rq_a VARCHAR2(100), --第一天 zao_b VARCHAR2(30),--早 zhong_b VARCHAR2(30),--中 wan_b VARCHAR2(30),--晚 sffrb VARCHAR2(100), --发热 sfksb VARCHAR2(100), --咳嗽 sfotb VARCHAR2(100), --呕吐 sfflb VARCHAR2(100), --乏力 yczzb VARCHAR2(100), --异常 rq_b VARCHAR2(100), --第二天 zao_c VARCHAR2(30),--早 zhong_c VARCHAR2(30),--中 wan_c VARCHAR2(30),--晚 sffrc VARCHAR2(100), --发热 sfksc VARCHAR2(100), --咳嗽 sfotc VARCHAR2(100), --呕吐 sfflc VARCHAR2(100), --乏力 yczzc VARCHAR2(100), --异常 rq_c VARCHAR2(100), --第三天 zao_d VARCHAR2(30),--早 zhong_d VARCHAR2(30),--中 wan_d VARCHAR2(30),--晚 sffrd VARCHAR2(100), --发热 sfksd VARCHAR2(100), --咳嗽 sfotd VARCHAR2(100), --呕吐 sffld VARCHAR2(100), --乏力 yczzd VARCHAR2(100), --异常 rq_d VARCHAR2(100),-- 第四天 zao_e VARCHAR2(30),--早 zhong_e VARCHAR2(30),--中 wan_e VARCHAR2(30),--晚 sffre VARCHAR2(100), --发热 sfkse VARCHAR2(100), --咳嗽 sfote VARCHAR2(100), --呕吐 sffle VARCHAR2(100), --乏力 yczze VARCHAR2(100), --异常 rq_e VARCHAR2(100)-- 第五天 )on commit preserve rows; */ BEGIN delete from TMP_YQDT_JMJKXXB; --插入居民信息 insert into TMP_YQDT_JMJKXXB (jmid,sq,xq,ld,mp,xm,sfzh,sjh) select id,sq,xq,ld,mp,xm,sfzh,sjh from T_QZGZ_YQDT where sfzh is not null order by sq,xq,ld,mp; --更新第一天时间 update TMP_YQDT_JMJKXXB set rq_a=(select to_char(p_sj,'yyyy-MM-dd') as rq_a from dual ); --更新第一天异常 update TMP_YQDT_JMJKXXB a set a.sffr=(select (case b.brfr when 1 then '发热' when 2 then '' else '' end) as sffr from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfks=(select (case b.brks when 1 then '咳嗽' when 2 then '' else '' end) as sfks from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfot=(select (case b.brot when 1 then '呕吐' when 2 then '' else '' end) as sfot from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sffl=(select (case b.brfx when 1 then '乏力' when 2 then '' else '' end) as sffl from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.yczz=(select (b.sffr||b.sfks||b.sfot||b.sffl) as yczz from TMP_YQDT_JMJKXXB b where a.sfzh=b.sfzh and rownum=1); --更新第一天体温 update TMP_YQDT_JMJKXXB a set a.zao_a=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='07:00:00' and b.sbsj<='12:00:00'); update TMP_YQDT_JMJKXXB a set a.zhong_a=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='12:00:01' and b.sbsj<='17:00:00'); update TMP_YQDT_JMJKXXB a set a.wan_a=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_a=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='17:00:01' and b.sbsj<='22:00:00'); commit; --更新第二天时间 update TMP_YQDT_JMJKXXB set rq_b=(select to_char(p_sj-1,'yyyy-MM-dd') as rq_b from dual ); --更新第二天异常 update TMP_YQDT_JMJKXXB a set a.sffrb=(select (case b.brfr when 1 then '发热' when 2 then '' else '' end) as sffr from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfksb=(select (case b.brks when 1 then '咳嗽' when 2 then '' else '' end) as sfks from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfotb=(select (case b.brot when 1 then '呕吐' when 2 then '' else '' end) as sfot from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfflb=(select (case b.brfx when 1 then '乏力' when 2 then '' else '' end) as sffl from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.yczzb=(select (b.sffrb||b.sfksb||b.sfotb||b.sfflb) as yczz from TMP_YQDT_JMJKXXB b where a.sfzh=b.sfzh and rownum=1); --更新第二天体温 update TMP_YQDT_JMJKXXB a set a.zao_b=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='07:00:00' and b.sbsj<='12:00:00'); update TMP_YQDT_JMJKXXB a set a.zhong_b=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='12:00:01' and b.sbsj<='17:00:00'); update TMP_YQDT_JMJKXXB a set a.wan_b=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_b=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='17:00:01' and b.sbsj<='22:00:00'); commit; --更新第三天时间 update TMP_YQDT_JMJKXXB set rq_c=(select to_char(p_sj-2,'yyyy-MM-dd') as rq_c from dual ); --更新第三天异常 update TMP_YQDT_JMJKXXB a set a.sffrc=(select (case b.brfr when 1 then '发热' when 2 then '' else '' end) as sffr from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfksc=(select (case b.brks when 1 then '咳嗽' when 2 then '' else '' end) as sfks from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfotc=(select (case b.brot when 1 then '呕吐' when 2 then '' else '' end) as sfot from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfflc=(select (case b.brfx when 1 then '乏力' when 2 then '' else '' end) as sffl from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.yczzc=(select (b.sffrc||b.sfksc||b.sfotc||b.sfflc) as yczz from TMP_YQDT_JMJKXXB b where a.sfzh=b.sfzh and rownum=1); --更新第三天体温 update TMP_YQDT_JMJKXXB a set a.zao_c=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='07:00:00' and b.sbsj<='12:00:00'); update TMP_YQDT_JMJKXXB a set a.zhong_c=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='12:00:01' and b.sbsj<='17:00:00'); update TMP_YQDT_JMJKXXB a set a.wan_c=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_c=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='17:00:01' and b.sbsj<='22:00:00'); commit; --更新第四天时间 update TMP_YQDT_JMJKXXB set rq_d=(select to_char(p_sj-3,'yyyy-MM-dd') as rq_d from dual ); --更新第四天异常 update TMP_YQDT_JMJKXXB a set a.sffrd=(select (case b.brfr when 1 then '发热' when 2 then '' else '' end) as sffr from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfksd=(select (case b.brks when 1 then '咳嗽' when 2 then '' else '' end) as sfks from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfotd=(select (case b.brot when 1 then '呕吐' when 2 then '' else '' end) as sfot from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sffld=(select (case b.brfx when 1 then '乏力' when 2 then '' else '' end) as sffl from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.yczzd=(select (b.sffrd||b.sfksd||b.sfotd||b.sffld) as yczz from TMP_YQDT_JMJKXXB b where a.sfzh=b.sfzh and rownum=1); --更新第四天体温 update TMP_YQDT_JMJKXXB a set a.zao_d=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='07:00:00' and b.sbsj<='12:00:00'); update TMP_YQDT_JMJKXXB a set a.zhong_d=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='12:00:01' and b.sbsj<='17:00:00'); update TMP_YQDT_JMJKXXB a set a.wan_d=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_d=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='17:00:01' and b.sbsj<='22:00:00'); commit; --更新第五天时间 update TMP_YQDT_JMJKXXB set rq_e=(select to_char(p_sj-4,'yyyy-MM-dd') as rq_e from dual ); --更新第五天异常 update TMP_YQDT_JMJKXXB a set a.sffre=(select (case b.brfr when 1 then '发热' when 2 then '' else '' end) as sffr from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfkse=(select (case b.brks when 1 then '咳嗽' when 2 then '' else '' end) as sfks from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sfote=(select (case b.brot when 1 then '呕吐' when 2 then '' else '' end) as sfot from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.sffle=(select (case b.brfx when 1 then '乏力' when 2 then '' else '' end) as sffl from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1); update TMP_YQDT_JMJKXXB a set a.yczze=(select (b.sffre||b.sfkse||b.sfote||b.sffle) as yczz from TMP_YQDT_JMJKXXB b where a.sfzh=b.sfzh and rownum=1); --更新第五天体温 update TMP_YQDT_JMJKXXB a set a.zao_e=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='07:00:00' and b.sbsj<='12:00:00'); update TMP_YQDT_JMJKXXB a set a.zhong_e=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='12:00:01' and b.sbsj<='17:00:00'); update TMP_YQDT_JMJKXXB a set a.wan_e=(select b.brtw from T_QZGZ_MRJC b where a.jmid=b.sbjm and a.rq_e=to_char(b.sbrq,'yyyy-MM-dd') and rownum=1 and b.sbsj>='17:00:01' and b.sbsj<='22:00:00'); commit; open p_cur for select mp.dz,a.xm,a.sfzh,a.sjh,a.zao_a,a.zhong_a,a.wan_a,a.yczz,a.rq_a,a.zao_b,a.zhong_b,a.wan_b,a.yczzb,a.rq_b,a.zao_c,a.zhong_c,a.wan_c,a.yczzc,a.rq_c, a.zao_d,a.zhong_d,a.wan_d,a.yczzd,a.rq_d,a.zao_e,a.zhong_e,a.wan_e,a.yczze,a.rq_e from TMP_YQDT_JMJKXXB a left join T_dmdz_mp mp on mp.id=a.mp where a.sq=p_fw; end P_YQGL_JMJKXX; end YQSBJKXX;
求教;程序中的Print_Sq(list3)为什么输不出来
#include<iostream.h> #include <stdlib.h> #define LIST_INIT_SIZE 100//线性表储存空间的初始分配量 #define LiSTINCREMENT 10//线性表储存空间的分配增量 #define OVERFLOW -2 #define ERROR 0 #define OK 1 typedef int Status; typedef int ElemType; typedef struct { ElemType *elem; //储存空间基址 int length; //当前长度 int listsize; //但前分配储存容量 }SqList; Status InitList_Sq(SqList &L) { // 构造一个空的线性表L。 L.elem = new ElemType[LIST_INIT_SIZE]; if (!L.elem) return OVERFLOW; // 存储分配失败 L.length = 0; // 长度为0 L.listsize = LIST_INIT_SIZE; // 初始存储容量 return OK; } Status ListInsert_Sq(SqList &L,int i,ElemType e) { ElemType *p,*q; ElemType *newbase; if(i<1||i>L.length+1) return ERROR; if(L.length>=L.listsize) { newbase=(ElemType *)realloc(L.elem,(L.listsize+LiSTINCREMENT)*sizeof(ElemType)); if(!newbase) return OVERFLOW; L.elem=newbase; L.listsize+=LiSTINCREMENT; } q=&(L.elem[i-1]); for(p=&(L.elem[L.length-1]);p>=q;--p) *(p+1)=*p; *q=e; ++L.length; return OK; } Status InsertList_Sq(SqList &L,int i,ElemType e) { i=L.length; L.elem[i]=e; ++L.length; return L.elem[i]; } int GetList_Sq(SqList L,int i,ElemType &e) { if(i>0 && i<=L.length) { return L.elem[i]; } else return ERROR; } int LocateElem_Sq(SqList L, ElemType e) { // 在顺序表中查询数据元素e,若存在,则返回它的位序,否则返回 0 int i = 1; // i 的初值为第 1 元素的位序 ElemType *p = L.elem; // p 的初值为第 1 元素的存储位置 while (i <= L.length && *p!=e) { ++i; ++p; } if (i <= L.length) return i; else return 0; } void Create_Sq(SqList &L) { cout<<"创建线性表"<<endl; cout<<"请输入线性表元素个数:"; int count; cin>>count; for(int i=0;i<count;i++) { cout<<"请输入第"<<i+1<<"个数:"; cin>>L.elem[i]; ++L.length; } } void Print_Sq(SqList &L) { cout<<"请输出线性表:"<<endl; for(int i=0;i<L.length;i++) cout<<L.elem[i]<<" "; cout<<endl; } int ListLength(SqList L) { return L.length; } void MergeList_Sq(SqList La,SqList Lb,SqList &Lc) { ElemType e; InitList_Sq(La); InitList_Sq(Lb); InitList_Sq(Lc); int La_len,Lb_len,Lc_len; La_len=ListLength(La); Lb_len=ListLength(Lb); Lc_len=ListLength(Lc); for(int i=0;i<=Lb_len;i++) { GetList_Sq(Lb,i,e); if(GetList_Sq(Lb,i,e)==LocateElem_Sq(La,e)) InsertList_Sq(Lc,i,e); } } //集合的并 void main() { SqList list1,list2,list3; InitList_Sq(list1); InitList_Sq(list2); InitList_Sq(list3); MergeList_Sq(list1,list2,list3); Create_Sq(list1); Create_Sq(list2); Print_Sq(list1); Print_Sq(list2); Print_Sq(list3); }
spring boot jpa 动态参数传表名,执行时自动添加单引号?
想通过sql语句自动创建表的列名但是传过来的两个参数值会自动添加了单引号,导致sq执行不成功。请问该怎么解决。 ``` @Modifying @Query(value="alter table ?1 add ?2 varchar(255) default ''",nativeQuery = true) void addTbcouponItemColumn(String table_name,String column_name); ```
(我原来问的不小心给删了)sql语句SQL logic error near ",": syntax error一般错误出在哪里
想达到的效果:主窗口上面是一个容器panel,里面有3个下拉框,左边是一个toolStrip菜单栏,剩余部分是一个panel1(用来显示五个子窗口),如第一个图;按完第一个按钮,在主窗口的panel1上显示第一个子窗口(Win1)的内容,效果如图二; a是comboBox1.Text,b 是comboBox2.Text,c是comboBox3.Text,为了方便子窗口调用主窗口public static string a; public static string b;public static string c;有令string e = Form1.a; string f = Form1.b; string g = Form1.c;不知道对不对 下面是主窗口用的部分程序 ``` public static string a; public static string b;public static string c;Win1 w1; w1 = new Win1();string a = comboBox1.Text; string b = comboBox2.Text; string c = comboBox3.Text; private void toolStripButton1_Click(object sender, EventArgs e) { this.panel1.Controls.Clear(); // 清空原有的控件 w1.TopLevel = false; // 非顶级窗口 w1.FormBorderStyle = FormBorderStyle.None; // 不显示标题栏 //w1.Dock = System.Windows.Forms.DockStyle.Fill; // 填充panel w1.WindowState = FormWindowState.Maximized; this.panel1.Controls.Add(w1); // 添加w1窗体 //w1.Show(this); w1.Show(); flag = true; } private void button1_Click(object sender, EventArgs e) { if (flag == true && flag1 == true && flag2 == true) { w1.Creatchart1(); } } ``` 下面是Win1的其中的一个chart的程序 ``` private void Creatchart1() { string e = Form1.a; string f = Form1.b; string g = Form1.c; string wax = e + f + g; string dbPath = @"D:\历年高考分数.db"; string sq = @"Data Source=" + dbPath; m = new SQLiteConnection(sq); m.Open(); SQLiteDataAdapter mAdapter = new SQLiteDataAdapter("select " + wax + ",yxlc from 表2", m); DataSet ds = new DataSet(); mAdapter.Fill(ds); DataTable dt = ds.Tables[0]; Series Series1 = new Series(); chart1.DataSource = dt; Series1.IsValueShownAsLabel = false;//是否显示图例 chart1.Series.Add(Series1); chart1.Series["Series1"].ChartType = SeriesChartType.Spline;//形状 chart1.Series[0].XValueMember = "yxlc";//X轴数据成员列 chart1.Series[0].YValueMembers = wax; chart1.Series[0].IsValueShownAsLabel = true;//显示坐标 chart1.DataBind(); chart1.BringToFront(); m.Close(); } ``` 启动时在mAdapter.Fill(ds);处显示其他信息: SQL logic error near ",": syntax error ,应该怎么改 ![图片说明](https://img-ask.csdn.net/upload/201908/30/1567155298_585744.png)![图片说明](https://img-ask.csdn.net/upload/201908/30/1567155318_123552.png)
如何把sqlite中某列的最大值取出来,并使取出的数加一
目的: 添加参数时,材料特性ID加一 ``` string zid = "select max(材料特性ID) from 特性"; int mid = 1; int id = Convert.ToInt32(zid) + mid; string str = "'" + txtName.Text + "'," + "'" + txtyunxinglicheng.Text + "'," + "'" + txtyingdu.Text + "'," + "'" + txtlashenqiangdu.Text + "'," + "'" + txtladuanshenchanglv.Text + "'," + "'" + yinsu + "'," + "'" + id + "'"; string sq = @"Data Source=" + dbPath; m = new SQLiteConnection(sq); m.Open(); string sql = "insert into " + tableName + " (传感器型号,运行里程,硬度,拉伸强度,拉断伸长率,因素,材料特性ID) values (" + str + ")"; SQLiteCommand command = new SQLiteCommand(sql, m); command.ExecuteNonQuery(); m.Close(); ``` 调试时int id = Convert.ToInt32(zid) + mid;id处显示为0,Convert.ToInt32(zid)好像没转换成功我该怎么改
在vs和sq一起作用的三层中,vs中删除按钮的后台代码怎么写
在vs和sq一起作用的三层中,vs中删除按钮的后台代码怎么写
推荐 130 个令你眼前一亮的网站,总有一个用得着
总结了大学生活两年来,发现的 130 余个黑科技网站,总有一个会让你眼前一亮,赶紧收藏!
在中国程序员是青春饭吗?
今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...
我在支付宝花了1分钟,查到了女朋友的开房记录!
在大数据时代下,不管你做什么都会留下蛛丝马迹,只要学会把各种软件运用到极致,捉奸简直轻而易举。今天就来给大家分享一下,什么叫大数据抓出轨。据史料证明,马爸爸年轻时曾被...
程序员请照顾好自己,周末病魔差点一套带走我。
程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
20道你必须要背会的微服务面试题,面试一定会被问到
写在前面: 在学习springcloud之前大家一定要先了解下,常见的面试题有那块,然后我们带着问题去学习这个微服务技术,那么就会更加理解springcloud技术。如果你已经学了springcloud,那么在准备面试的时候,一定要看看看这些面试题。 文章目录1、什么是微服务?2、微服务之间是如何通讯的?3、springcloud 与dubbo有哪些区别?4、请谈谈对SpringBoot 和S...
讲真,这两个IDE插件,可以让你写出质量杠杠的代码
周末躺在床上看《拯救大兵瑞恩》 周末在闲逛的时候,发现了两个优秀的 IDE 插件,据说可以提高代码的质量,我就安装了一下,试了试以后发现,确实很不错,就推荐给大家。 01、Alibaba Java 代码规范插件 《阿里巴巴 Java 开发手册》,相信大家都不会感到陌生,其 IDEA 插件的下载次数据说达到了 80 万次,我今天又贡献了一次。嘿嘿。 该项目的插件地址: https://github....
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
2020 年,大火的 Python 和 JavaScript 是否会被取而代之?
Python 和 JavaScript 是目前最火的两大编程语言,但是2020 年,什么编程语言将会取而代之呢? 作者 |Richard Kenneth Eng 译者 |明明如月,责编 | 郭芮 出品 | CSDN(ID:CSDNnews) 以下为译文: Python 和 JavaScript 是目前最火的两大编程语言。然而,他们不可能永远屹立不倒。最终,必将像其他编程语言一...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Flutter 会不会被苹果限制其发展?
这个可能性是存在的,而且不止是 flutter、react-native 、weex 、uni-app 、taro 、Hippy等都存在这个风险,虽然有些框架对比起 flutter 其他框架存在时间稍长,但是这不可否认它们一直都存在这个风向。 只要不是平台自己的亲儿子,那么肯定存在被限制发展的风险,所以这件事上是风险和收益之间的博弈,这是一个“后妈和前任之间的太极。” 先说现状 如今各大平台,如:...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
最全最强!世界大学计算机专业排名总结!
我正在参与CSDN200进20,希望得到您的支持,扫码续投票5次。感谢您! (为表示感谢,您投票后私信我,我把我总结的人工智能手推笔记和思维导图发送给您,感谢!) 目录 泰晤士高等教育世界大学排名 QS 世界大学排名 US News 世界大学排名 世界大学学术排名(Academic Ranking of World Universities) 泰晤士高等教育世界大学排名 中国共...
作为一名大学生,如何在B站上快乐的学习?
B站是个宝,谁用谁知道???? 作为一名大学生,你必须掌握的一项能力就是自学能力,很多看起来很牛X的人,你可以了解下,人家私底下一定是花大量的时间自学的,你可能会说,我也想学习啊,可是嘞,该学习啥嘞,不怕告诉你,互联网时代,最不缺的就是学习资源,最宝贵的是啥? 你可能会说是时间,不,不是时间,而是你的注意力,懂了吧! 那么,你说学习资源多,我咋不知道,那今天我就告诉你一个你必须知道的学习的地方,人称...
那些年,我们信了课本里的那些鬼话
教材永远都是有错误的,从小学到大学,我们不断的学习了很多错误知识。 斑羚飞渡 在我们学习的很多小学课文里,有很多是错误文章,或者说是假课文。像《斑羚飞渡》: 随着镰刀头羊的那声吼叫,整个斑羚群迅速分成两拨,老年斑羚为一拨,年轻斑羚为一拨。 就在这时,我看见,从那拨老斑羚里走出一只公斑羚来。公斑羚朝那拨年轻斑羚示意性地咩了一声,一只半大的斑羚应声走了出来。一老一少走到伤心崖,后退了几步,突...
一个程序在计算机中是如何运行的?超级干货!!!
强烈声明:本文很干,请自备茶水!???? 开门见山,咱不说废话! 你有没有想过,你写的程序,是如何在计算机中运行的吗?比如我们搞Java的,肯定写过这段代码 public class HelloWorld { public static void main(String[] args) { System.out.println("Hello World!"); } ...
【蘑菇街技术部年会】程序员与女神共舞,鼻血再次没止住。(文末内推)
蘑菇街技术部的年会,别开生面,一样全是美女。
Linux必懂知识大总结(补)
关机 1. 数据同步写入磁盘 sync 为了加快对磁盘上文件的读写速度,位于内存中的文件数据不会立即同步到磁盘上,因此关机之前需要先进行 sync 同步操作。 2. shutdown # /sbin/shutdown [-krhc] [时间] [警告讯息] -k : 不会关机,只是发送警告讯息,通知所有在线的用户 -r : 将系统的服务停掉后就重新启动 -h : 将系统的服务停掉后就...
立即提问