mysql查询自定义数据_实现自定义查询的数据库设计及实现(一)

需求

先说一下需求:实现用户自定义的查询,用户可以自定义要查询的列、自定义条件条件、自定义排序。除了查询使用外,还可以使用于各个需要根据条件进行约束的业务,如权限;

本设计和实现,很大部分是通过数据库和存储过程进行,界面只是让用户选择数据列和设置条件,并把这些内容保存在数据库中,查询是通过存储过程拼SQL语句完成,并把结果集返回。

设计结构

基础登记表-->查询设置表-->存储过程运行

1b0fc54f3d54eefc9593dd855a95b2a3.png

表设计

首先定义基础登记表,基础登记表分为三个部分:表登记、列登记、表间关系登记;

表登记的数据表包含如下字段:

字段描述

字段名

类型

说明

登记表自增长关键字

id_table

int

自增长

基础表

tablereg_name

varchar(60)

数据库中名称

基础表中文名

tablereg_cnname

varchar(60)

业务上显示的名称

关键字段名

prk_name

varchar(60)

关键字字段

关键字段中文名

prk_cnname

varchar(60)

关键字中文名称

审核后是否可以删除

checkdel_flag

char(1)

用户控制业务操作

使用后是否可以删除

useddel_flag

char(1)

用户控制业务操作

控制操作权限

belong_type

char(1)

用户控制业务操作

用户可配置

config_flag

char(1)

用户控制业务操作

业务主表标志

mainbusiness_flag

char(1)

用户控制业务操作

是否需要审核

check_flag

char(1)

用户控制业务操作

需要定义审批流程

checkflow_type

char(1)

用户控制业务操作

审批流程ID

id_workflow

int

用户控制业务操作

数据库名称

schema_name

varchar(100)

用户控制业务操作

消息通知标志

message_flag

char(1)

用户控制业务操作

是否权限控制

permission_flag

char(1)

用户控制业务操作

列登记的数据表包含如下字段:

字段描述

字段名

类型

说明

自增长关键字

id_column

int

自增长关键字

登记表关键字

id_table

int

归属表的ID

顺序号

serial_num

int

标示列的顺序

字段表

column_name

varchar(60)

字段中文名

column_cnname

varchar(60)

数据类型

data_type

char(1)

1 数字;2 字符;3 时间;

原始数据类型

data_type_original

varchar(20)

记录数据库中的数据类型 如 int datetime 等

原始列数据类型

column_type_original

varchar(30)

是否权限控制

permission_flag

char(1)

业务使用

下拉列表ID

id_list

int

标识下拉框的数据源,可以是枚举或是数据源

表间关系登记表

字段描述

字段名

类型

说明

登记表关系ID关键字

id_tabrela

int

自增长

主表

id_table

int

表的ID

关联表

id_table_rela

int

表的ID

主表字段名

column_name

varchar(100)

主表的关键字

主表字段中文名

column_cnname

varchar(100)

主表的关键字中文名

关联表字段

column_name_rela

varchar(100)

关联表的关键字,一般是外键

关联表别名

relatable_name

varchar(100)

关联名别名,显示用

关联表查询别名

tableas_name

varchar(100)

拼SQL语句时表别名

这三个表的数据,根据数据库中系统表的内容进行初始化填写。并且开发了一个界面,进行一些业务上的设置,主要是设置表中“用户控制业务操作”的那些字段;

后续内容请看第二部分;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575822.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

poj 1321 棋盘问题

题目&#xff1a; http://poj.org/problem?id1321 八皇后问题&#xff0c;用dfsj即可。 源代码&#xff1a; 1 #include <iostream>2 #include<stdio.h>3 #include<cstring>4 using namespace std;5 int a[10][10];6 int visit[10];7 int n,k,sum;8 __int64…

php mysql-proxy报错_MySQL-proxy代理导致PHP PDO::ATTR_EMULATE_PREPARES的预处理出错,MySQL报General error: 1243错误...

背景&#xff1a;用的ThinkPHP5的框架。(相比之前的3.2版本&#xff0c;版本5都用了PDO处理数据库)症状&#xff1a;SQLSTATE[HY000]: General error: 1243 Unknown prepared statement handler (1) given to mysqld_stmt_execute具体的错误SQL&#xff0c;可能是任何一条正常的…

异步分页ajax

****jsp页面代码 <% page language"java" pageEncoding"utf-8"%> <% taglib prefix"s" uri"/struts-tags" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or…

python函数模块_06.Python函数和模块

函数基础目标函数的快速体验函数的基本使用函数的参数函数的返回值函数的嵌套调用在模块中定义函数函数的快速体验1.1 快速体验所谓函数&#xff0c;就是把 具有独立功能的代码块 组织为一个小模块&#xff0c;在需要的时候 调用函数的使用包含两个步骤&#xff1a;定义函数 —…

浙江大学PAT上机题解析之1008. 数组元素循环右移问题 (20)

1008. 数组元素循环右移问题 (20) 时间限制 400 ms内存限制 32000 kB代码长度限制 8000 B判题程序 Standard一个数组A中存有N&#xff08;N>0&#xff09;个整数&#xff0c;在不允许使用另外数组的前提下&#xff0c;将每个整数循环向右移M&#xff08;M>0&#x…

mysql11导入数据_MySQL专题11之MySQL导出数据、MySQL导入数据

1、MySQL导出数据- MySQL中你可以使用SELECT...INTO OUTFILE语句来简单的导出数据到文本文件中。a、使用SELECT...INTO OUTFILE- 以下实例中我们将数据库runoob_tbl数据导出到/tmp/tutorials.txt文件中&#xff1a;mysql> SELECT * FROM runoob_tbl-> INTO OUTFILE /tm…

向量叉乘判断两向量之间是顺时针还是逆时针

转自http://blog.163.com/shiliping_007/blog/static/25772011201071744031933/ 向量积 a x b (^n) * |a| * |b| * sin<a, b>, 其中^n是同时垂直于a/b且符合右手定则的单位向量。若已知向量a (ax, ay, az), b (bx, by, bz); 则 a x b (ay * bz - by * az, az * bx - …

java 生成随机数_Java 生成随机数的 N 种方法

原标题&#xff1a;Java 生成随机数的 N 种方法www.baeldung.com/java-generating-random-numbers1.引言本文将探讨用 Java 生成随机数的不同方法。2.Java APIJava API 提供了几种随机数生成方法。让我们一起来了解一下。2.1.java.lang.MathMath 类中的 random 方法返回一个 [0…

剑指offer--面试题13

题目&#xff1a;以O(1)的时间复杂度删除单链表中的某个节点 自己所写代码如下&#xff1a; //以O(1)时间删除链表节点 //要求&#xff1a;单向链表&#xff0c;头指针&#xff0c;待删节点指针//链表节点 struct ListNode {int m_nValue;ListNode* m_pNext; }; //O(n)的解法&a…

重启java_让Java程序自动重启的实现方法(推荐)

要让一个java程序自动重启还真不容易的&#xff0c;重启分两步&#xff0c;首先是结束程序&#xff0c;这个简单&#xff0c;只要运行System.exit()就可以了。然后是启动&#xff0c;这个就难了&#xff0c;这个时候程序都已经结束了&#xff0c;就像一个人死了就不可能再自己站…

【HDOJ】4602 Partition

【题目】http://acm.hdu.edu.cn/showproblem.php?pid4602 【报告】 直接贴上标程解题报告&#xff1a;&#xff08;虽然有些纠结&#xff0c;试一下就弄通了。。&#xff09; Problem C. Partition 我们可以特判出n< k的情况。 对于1< k&#xff0c;我们可以等效为n个点…

json 字符串 java_Java中string字符串转json对象方法

Java中string字符串转json对象方法Java利用JSONObject进行string字符串转换成JSON对象转换实例一public class StringToJSON {public static void main(String[] args) throws JSONException{System.out.println("abc");//定义JSON字符串String jsonStr "{\&qu…

poj 3026 Borg Maze (最小生成树+bfs)

有几个错误&#xff0c;调试了几个小时&#xff0c;样例过后 1Y. 题目&#xff1a;http://poj.org/problem?id3026 题意&#xff1a;就是让求A们和S的最小生成树 先用bfs找每两点的距离&#xff0c;再建树。没剪枝 63MS。 1 #include <iostream>2 #include<cstdio&g…

webview 调用java_Android中在WebView里实现Javascript调用Java类的方法

为了方便网页和Android应用的交互&#xff0c;Android系统提供了WebView中JavaScript网页脚本调用Java类方法的机制。只要调用addJavascriptInterface方法即可映射一个Java对象到JavaScript对象上。1、映射Java对象到JavaScript对象上mWebView (WebView) findViewById(R.id.wv…

VS的一部分快捷键

快捷键 功能CTRL SHIFT B 生成解决方案CTRL F7 生成编译CTRL O 打开文件CTRL SHIFT O 打开项目…

java 合并流_Java Stream 流实现合并操作示例

本文实例讲述了Java Stream 流实现合并操作。分享给大家供大家参考&#xff0c;具体如下&#xff1a;1. 前言Java Stream Api提供了很多有用的 Api 让我们很方便将集合或者多个同类型的元素转换为流进行操作。今天我们来看看如何合并 Stream 流。2. Stream 流的合并Stream 流合…

java 去掉 t_java中的“\t”

对于初学者来说&#xff0c;java中的"\t"和空格总是让人迷惑&#xff0c;其实很简单&#xff0c;通过一个例子就能很快明白&#xff01;比如说打印九九乘法表&#xff01;先来看用空格的效果&#xff01;1 package cn.edu.nwpu.java;23 public class MultiplicationT…

如何检测文件中的违禁词和小于规定大小的文件?

1 <?php2 foreach(array(a.txt,b.txt,c.txt) as $v){3 4 $file./article/.$v;5 6 if(filesize($file)<10){7 8 echo $v."文件小于10字节&#xff0c;已经被删除"."<br/>";9 unlink($file); 10 continue;} 11 $confile_get_contents(…

java excel 操作方式_Java读写Excel基本操作

Apache POI是Apache软件基金会的开放源码函式库&#xff0c;POI提供API给Java程式对Microsoft Office格式档案读和写的功能。接口&#xff1a;HSSF &#xff0d; Microsoft ExcelXSSF &#xff0d; Microsoft Excel OOXML(07以上版本)HWPF &#xff0d; Microsoft WordHSLF &am…

C语言根据日期(年,月,日)判断星期几(使用基姆拉尔森计算公式)

C语言根据日期判断星期几&#xff08;使用基姆拉尔森计算公式&#xff09; 算法如下&#xff1a; 基姆拉尔森计算公式W (d2*m3*(m1)/5yy/4-y/100y/400) mod 7 在公式中d表示日期中的日数&#xff0c;m表示月份数&#xff0c;y表示年数。 注意&#xff1a;在公式中有个与其他公式…