DouNet学习_代码生成器
string conn = "Data Source={0};Initial Catalog={1};User Id={2};Password={3}";
//点击链接
private void btnLink_Click(object sender, EventArgs e)
{
SqlHelper.connstr =
string.Format(conn, txtServer.Text.Trim(), "master", txtUserName.Text.Trim()
, txtPWD.Text.Trim());
cboDatabase.DisplayMember = "name";
cboDatabase.DataSource =
SqlHelper.ExecuteDataTable("select name from SYS.databases ", CommandType.Text);
}
//当选择数据库的索引发生改变时
private void cboDatabase_SelectedIndexChanged(object sender, EventArgs e)
{
treeView1.Nodes.Clear();
string databasename = cboDatabase.Text;
SqlHelper.connstr =
string.Format(conn, txtServer.Text.Trim(), databasename, txtUserName.Text.Trim(),
txtPWD.Text.Trim());
TreeNode partent = new TreeNode();
partent.Text = databasename;
treeView1.Nodes.Add(partent);
TreeNode sheet = new TreeNode();
sheet.Text = "数据表";
partent.Nodes.Add(sheet);
DataTable dtsheet =
SqlHelper.ExecuteDataTable("select TABLE_NAME ,TABLE_TYPE
from INFORMATION_SCHEMA.TABLES where TABLE_TYPE ='BASE TABLE'", CommandType.Text);
AddTreeNode(dtsheet, sheet);
TreeNode view = new TreeNode();
view.Text = "视图";
partent.Nodes.Add(view);
DataTable dtview =
SqlHelper.ExecuteDataTable("select TABLE_NAME ,TABLE_TYPE
from INFORMATION_SCHEMA.TABLES where TABLE_TYPE ='VIEW'", CommandType.Text);
AddTreeNode(dtview, view);
partent.ExpandAll();
ChangeText();
}
void ChangeText()
{
txtBll.Text = cboDatabase.Text + "Bll";
txtDAL.Text = cboDatabase.Text + "DAL";
txtModel.Text = cboDatabase.Text + "Model";
txtDatabase.Text = "DBHelper";
}
//把得到的每个数据表或视图加载到节点上
private void AddTreeNode(DataTable dt, TreeNode tn)
{
foreach (DataRow item in dt.Rows)
{
TreeNode node = new TreeNode();
node.Text = item["TABLE_NAME"].ToString();
tn.Nodes.Add(node);
}
}
private void Form1_Load(object sender, EventArgs e)
{
rboModel.Checked = true;
}
//点击代码生成
private void btnRes_Click(object sender, EventArgs e)
{
tabControl1.SelectedIndex = ;
if (rboModel.Checked)
{
//生成实体类
)
{
txtCode .Text = CreateModel();
}
else
{
MessageBox.Show("请选择数据表或视图");
}
}
if (rboDAL.Checked)
{
//生成数据访问层类
}
if (rboBll.Checked)
{
//生成业务逻辑层类
}
}
//生成Model类
string CreateModel()
{
string sheetname = treeView1.SelectedNode.Text;
StringBuilder sb = new StringBuilder();
DataTable dt =
SqlHelper.ExecuteDataTable("select COLUMN_NAME ,DATA_TYPE
from INFORMATION_SCHEMA.COLUMNS where TABLE_NAME ='" + sheetname + "'", CommandType.Text);
sb.AppendLine("using System;");
sb.AppendLine("namespace " + ToPascal(txtModel.Text) + "");
sb.AppendLine("{");
sb.AppendLine("\tpublic class " + ToPascal(sheetname) + "");
sb.AppendLine("\t{");
foreach (DataRow item in dt.Rows)
{
string columnname = item["COLUMN_NAME"].ToString();
string type = ChangeType(item["DATA_TYPE"].ToString());
sb.AppendLine("\t\tprivate " + type + " " + ToCamel(columnname) + "");
sb.AppendLine("\t\tpublic " + type + " " + ToPascal(columnname) + "");
sb.AppendLine("\t\t\tget{return " + ToCamel(columnname) + ";}");
sb.AppendLine("\t\t\tset{" + ToCamel(columnname) + "=value;}");
}
sb.AppendLine("\t}");
sb.AppendLine("}");
return sb.ToString();
}
//判断数据类型
string ChangeType(string str)
{
string res = "string";
switch (str)
{
case "int": res = "int";
break;
case "datatime": res = "DataTime";
break;
case "bit": res = "bool";
break;
default:
break;
}
return res;
}
//把一个字符串的首字母转换成小写
string ToCamel(string str)
{
, ).ToLower() + str.Substring();
}
//把一个字符串的首字母转换成小写
string ToPascal(string str)
{
, ).ToUpper() + str.Substring();
}
DouNet学习_代码生成器的更多相关文章
- DouNet学习_收发邮件
一.收发邮件 --->第一步:发邮件首先要有发送者的邮箱地址和登录的密码才能发送 这些都写在APP里 不要写死 --->第二步:发邮件就要有网络,要添加net.Mail命名空间 要发送的 ...
- python学习_数据处理编程实例(二)
在上一节python学习_数据处理编程实例(二)的基础上数据发生了变化,文件中除了学生的成绩外,新增了学生姓名和出生年月的信息,因此将要成变成:分别根据姓名输出每个学生的无重复的前三个最好成绩和出生年 ...
- Linux操作系统学习_操作系统是如何工作的
实验五:Linux操作系统是如何工作的? 学号:SA1****369 操作系统工作的基础:存储程序计算机.堆栈(函数调用堆栈)机制和中断机制 首先要整明白的一个问题是什么是存储程序计算机?其实存储程序 ...
- 『TensorFlow』SSD源码学习_其一:论文及开源项目文档介绍
一.论文介绍 读论文系列:Object Detection ECCV2016 SSD 一句话概括:SSD就是关于类别的多尺度RPN网络 基本思路: 基础网络后接多层feature map 多层feat ...
- jQuery源代码学习_工具函数_type
jquery源代码学习_工具函数_type jquery里面有一个很重要的工具函数,$.type函数用来判断类型,今天写这篇文章,是来回顾type函数的设计思想,深入理解. 首先来看一下最终结果: 上 ...
- TypeScript学习_入门向
TypeScript学习_入门向 1-TypeScript简介 首先官网祭天 ---> https://www.tslang.cn/ TypeScript 是 JavaScript 的一个超集, ...
- 《mysql必知必会》学习_第八章_20180730_欢
第八章学习LIKE操作符,百分百(%)通配符,下划线(_)通配符 P47 select prod_id,prod_name from products where prod_name LIKE 'je ...
- labview学习_入门篇(一)
写在前面的话: 在上大学的时候,实验室的老师推荐用labview工具编写上位机软件,当时不想用labview,感觉不写代码心里不踏实,后来用vb和matalb开发了上位机软件.但现在由于部门的几款工具 ...
- Deep Learning 17:DBN的学习_读论文“A fast learning algorithm for deep belief nets”的总结
1.论文“A fast learning algorithm for deep belief nets”的“explaining away”现象的解释: 见:Explaining Away的简单理解 ...
随机推荐
- 浅谈Linux下的五种I/O模型
一.关于I/O模型的引出 我们都知道,为了OS的安全性等的考虑,进程是无法直接操作I/O设备的,其必须通过系统调用请求内核来协助完成I/O动作,而内核会为每个I/O设备维护一个buffer.如下图所 ...
- JS实现 页面提交防刷新等待提示
//关闭等待窗口 function closediv() { //Close Div document.body.removeChild(document.getElementById("b ...
- java验证码-汉字验证码
今天整理了一个java实现的汉字输入验证码 主要包含两个类,一个是生成验证码,一个是判断验证码输入是否正确 实现原理非常简单,将汉字和干扰线生成图片并将汉字保存到session,前台获取每次生成验证码 ...
- 谈谈防止Ajax重复点击提交
首先说说防止重复点击提交是什么意思. 我们在访问有的网站,输入表单完成以后,单击提交按钮进行提交以后,提交按钮就会变为灰色,用户不能再单击第二次,直到重新加载页面或者跳转.这样,可以一定程度上防止用户 ...
- 利用SOLR搭建企业搜索平台 之——solr配置solrconfig.xml
来源:http://blog.csdn.net/zx13525079024/article/details/25310781 solrconfig.xml配置文件主要定义了SOLR的一些处理规则,包括 ...
- centos chrome
在centos6.X和redhat enterprise 中安装chrome,我找了很久都不行,今天终于找到了可以用下脚本那安装: #! /bin/bash # Google Chrome Insta ...
- SQLServer2008 行转列3
with a as ( select 日期,学号,名字, '语文' as 科目,语文 as 分数 from tsco union all select 日期,学号,名字, '数学' as 科目,数学 ...
- [CF580B]Kefa and Company(滑动窗口)
题目链接:http://codeforces.com/problemset/problem/580/B 某人有n个朋友,这n个朋友有钱数m和关系s两个属性.问如何选择朋友,使得这些朋友之间s最大差距小 ...
- css圣杯布局、等高布局
所谓圣杯布局,就是自适应浏览器的分辨率,也称双飞翼布局. 例子: <style> body{margin:0;} .center{height:600px;background:#f60; ...
- (转载)C语言 数组与指针的区别
1) 字符串指针变量是个变量,指向字符串的首地址:而字符串数组名是个常量,为字符串数组第一个元素的地址: 2)字符串指针变量可以赋值,而字符串数组名不能赋值:对于字符数组只能对各个元素赋值,不能用以下 ...