随心笔记(二)

连接数据库:https://v.youku.com/v_show/id_XNzU4ODI2MDcy.html(视屏)

1、通过ADO.NET的Connection组建来建立和数据库的连接。

2、Command组建来进行管理数据查询命令。

3、DataAdapter组建调用数据库查询命令进行数据的查询,将查询数据填充到数据缓存DataSet中,再将DataSet绑定到某一信息查询窗体中的DataGridView控件实例来进行显示。

 

Oracle数据库客户端下载地址http://pan.baidu.com/s/1dDAG4Jf

 

注意Oracle数据库的查询语句表需要加  “ ”

Ex:  select * from  “admin”;

连接数据库步骤:

  1. 引用命名空间

引用system.Data.OracleClient

  1. 创建Oracle数据库的连接对象

OracleConnection oc = new OracleConnection(“server=ocrl;uid=system;pwd=123456;”);

  1. 打开连接 oc.open();

Console.WriteLine(“Open”);

测试连接。(查询语句查询)

***Oracle数据库带参数查询规则

“Select * from user where Id=:id”; //注意Oracle带参数用冒号。

 

**使用C#开发窗体控件的数据 的增删改查链接地址

https://jingyan.baidu.com/album/5bbb5a1b0b856213eaa17946.html?picindex=2(主要实现控件是GridView控件来实现)。

 

**登录中判断获取的用户名和数据库中的用户名是否相同;

if(name==textBox1.Text.Trim()&&pass==textBox2.Text.Trim())

textBox1.Text.Trim()是指你输入框中输入的去掉空格后的文本。

 

注意在Oracle数据库中建表中的字段关键字的使用int类型的用number来代替,通常报缺失有括号错误。

 

 

select DISTINCT to_char(t.finished_time - 8 / 24, 'yyyy-MM-dd') 

from lj_mes_maobang_checked t where t.created_by between to_date(p_timefrom,'yyyy-mm-dd hh24:mi:ss') 

and to_date(p_timeend,'yyyy-mm-dd hh24:mi:ss');时间区间范围设置参数为字符串。

 

 listagg() within GROUP () over  将多行记录在一行显示

*****获取文本框中的内容:

pwd.Text.Trim()

 

1C#项目结构

  • 程序的第一行 using System; - using 关键字用于在程序中包含 System 命名空间。 一个程序一般有多个 using 语句。
  • 下一行是 namespace 声明。一个 namespace 里包含了一系列的类。HelloWorldApplication 命名空间包含了类 HelloWorld
  • 下一行是 class 声明。类 HelloWorld 包含了程序使用的数据和方法声明。类一般包含多个方法。方法定义了类的行为。在这里,HelloWorld类只有一个 Main 方法。
  • 下一行定义了 Main 方法,是所有 C# 程序的 入口点Main 方法说明当执行时 类将做什么动作。
  • 下一行 /.../ 将会被编译器忽略,且它会在程序中添加额外的 注释
  • Main 方法通过语句

Console.WriteLine("Hello World");

指定了它的行为。

WriteLine 是一个定义在 System 命名空间中的 Console 类的一个方法。该语句会在屏幕上显示消息 "Hello, World!"

  • 最后一行 Console.ReadKey(); 是针对 VS.NET 用户的。这使得程序会等待一个按键的动作,防止程序从 Visual Studio .NET 启动时屏幕会快速运行并关闭。

2.笔记篇:

举例 下面是阶乘的递归算法,其中判断条件如果 num>0 则返回 num *Jc(num - 1),否则返回 1

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

​

namespace jiecheng

{

   class jiecheng

  {

       public int Jc(int num)

      {

           

           return num > 0 ? num *Jc(num - 1):1;  //如果num>0则返回num *Jc(num - 1),否则返回1

      }

  }

//定义方法,如果输入数值不为0,则输出该数值的阶乘结果。

​

   class excutejiecheng

 

  {

       static void Main(string[] args)

      {

           jiecheng n = new jiecheng();

           int result = n.Jc(Convert.ToInt16(Console.ReadLine()));

           Console.WriteLine("result is {0}",result);

           Console.ReadKey();

      }

  }

}

​

​

​

3、笔记之总结

 

连接数据库:https://v.youku.com/v_show/id_XNzU4ODI2MDcy.html(视屏)

 

1、通过ADO.NETConnection组建来建立和数据库的连接。

 

2Command组建来进行管理数据查询命令。

 

3DataAdapter组建调用数据库查询命令进行数据的查询,将查询数据填充到数据缓存DataSet中,再将DataSet绑定到某一信息查询窗体中的DataGridView控件实例来进行显示。

 

  

 

Oracle数据库客户端下载地址http://pan.baidu.com/s/1dDAG4Jf

 

  

 

注意Oracle数据库的查询语句表需要加 “ ”

 

**Ex: select * from “admin”**

 

连接数据库步骤:

 

1     引用命名空间

 

引用system.Data.OracleClient

 

2     创建Oracle数据库的连接对象

 

OracleConnection oc = new OracleConnection“server=ocrluid=system;pwd=123456;”;

 

3     打开连接 oc.open();

 

Console.WriteLine(“Open”);

 

测试连接。(查询语句查询)

 

***Oracle数据库带参数查询规则

 

“Select * from user where Id=:id”; //注意Oracle带参数用冒号。

 

  

 

**使用C#开发窗体控件的数据 的增删改查链接地址

 

https://jingyan.baidu.com/album/5bbb5a1b0b856213eaa17946.html?picindex=2(主要实现控件是GridView控件来实现)。

 

  

 

**登录中判断获取的用户名和数据库中的用户名是否相同;

 

if(name==textBox1.Text.Trim()&&pass==textBox2.Text.Trim())

 

textBox1.Text.Trim()是指你输入框中输入的去掉空格后的文本。

 

  

 

注意在Oracle数据库中建表中的字段关键字的使用int类型的用number来代替,通常报缺失有括号错误。

 

  

 

select DISTINCT to_char(t.finished_time - 8 / 24, 'yyyy-MM-dd') 

 

  from lj_mes_maobang_checked t where t.created_by between to_date(p_timefrom,'yyyy-mm-dd hh24:mi:ss') 

 

  and to_date(p_timeend,'yyyy-mm-dd hh24:mi:ss');时间区间范围设置参数为字符串。

 

  

 

  **listagg() within GROUP () over** **将多行记录在一行显示**

 

使用foreach 进行数据的遍历,避免死循环

 

     *int [] pins = {9,2,3,4,5};*

 

     *foreach(int pin in   pins ){*

 

         *Console.WriteLine(pin);*

 

     *}*

 

plsql编程规范:

 

定义变量时   建议用v_作为前缀   v_sal

 

定义常量   c_作为前缀

 

定义游标   _cursor作为后缀 

​

## 4Oracle数据库中各函数的意义以及用法

C#中方法的定义

2.访问修饰符 返回值 方法名 参数列表 方法主体

egpublic int getMaxint num1 int num2

           {

                      方法体;

                      return 返回值;

           }

连接数据库:https://v.youku.com/v_show/id_XNzU4ODI2MDcy.html(视屏)

1、通过ADO.NETConnection组建来建立和数据库的连接。

2Command组建来进行管理数据查询命令。

3DataAdapter组建调用数据库查询命令进行数据的查询,将查询数据填充到数据缓存DataSet中,再将DataSet绑定到某一信息查询窗体中的DataGridView控件实例来进行显示。

Oracle数据库客户端下载地址http://pan.baidu.com/s/1dDAG4Jf

注意Oracle数据库的查询语句表需要加 “ ”

Ex: select * from “admin”

连接数据库步骤:

1 引用命名空间

引用system.Data.OracleClient

2 创建Oracle数据库的连接对象

OracleConnection oc = new OracleConnection“server=ocrluid=system;pwd=123456;”;

3 打开连接 oc.open();

Console.WriteLine(“Open”);

测试连接。(查询语句查询)

***Oracle数据库带参数查询规则

“Select * from user where Id=:id”; //注意Oracle带参数用冒号。

**使用C#开发窗体控件的数据 的增删改查链接地址

https://jingyan.baidu.com/album/5bbb5a1b0b856213eaa17946.html?picindex=2(主要实现控件是GridView控件来实现)。

**登录中判断获取的用户名和数据库中的用户名是否相同;

if(name==textBox1.Text.Trim()&&pass==textBox2.Text.Trim())

textBox1.Text.Trim()是指你输入框中输入的去掉空格后的文本。

注意在Oracle数据库中建表中的字段关键字的使用int类型的用number来代替,通常报缺失有括号错误。

select DISTINCT to_char(t.finished_time - 8 / 24, 'yyyy-MM-dd')

from lj_mes_maobang_checked t where t.created_by between to_date(p_timefrom,'yyyy-mm-dd hh24:mi:ss')

and to_date(p_timeend,'yyyy-mm-dd hh24:mi:ss');时间区间范围设置参数为字符串。

listagg() within GROUP () over 将多行记录在一行显示

***获取文本框中的内容:

pwd.Text.Trim()

3.Oracle数据库的sqlplsql基础语法

1)在Oracle数据库中想要复制已存在的表的结构和数据所需要的语法是:

create table 新表的名称 as select * from 需要复制的表

2Oracle数据库中插入数据语法

insert into 目标表 select * from 数据表 (条件 如果限定条件则插入限定列 如果未限定则插入所有数据 前提条件两张表的结构完全一样)

3Oracle数据库中复制已有表结构但不复制数据

create table 新表的名称 as select * from 需要复制的表 where 1=2

--复制表结构和数据 create table lj_mes_maobang_checkedtest as select * from lj_mes_maobang_checkedlp --查询所有数据 select t.* from lj_mes_maobang_checkedlp t --插入数据 insert into lj_mes_maobang_checkedlp (select t.* from lj_mes_maobang_checked t ) --更新表中的某列数据 update lj_mes_maobang_checkedlp t set t.work_order = '111111k' where t.checked_id = '640385' --查询修改后的数据(执行去重操作) select distinct t.* from lj_mes_maobang_checkedlp t where t.work_order = '111111k'

--删除表中的数据 特定列的值 删除完成查询是否删除 delete from lj_mes_maobang_checkedlp t where t.work_order = '111111k' select count() from lj_mes_maobang_checkedlp t where t.work_order = '111111k' --commit 之后则无法回滚 delete 之后是可以恢复的,如果一旦提交则无法恢复 commit; rollback;

1.基本结构

create replace procedure 存储过程的名字

参数1 in number

参数2 in number

is

变量 1 integer =0

变量2 达特;

begin

执行体

end 存储过程名字;

2.使用if 判断

if v_test = 1 then

      begin

do something

end;

end if;

3.Windows文件流的读取

//1\定义一个 directoryInfo对象,

Directoryinfo file = new Directoryinfo(@"文件路径")

//2\获取文件的名称和文件的大小

Fileinfo [] f = file.getFiles();

//3\遍历循环

foreach(FileInfo file in f)

{

           Console.WriteLine("FileName: {0},Size{1}",file.Name,File.length)

}

4 C#实现将EXCEL数据导入数据库

 

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Data;

using System.Data.OleDb;

using System.Configuration;

using System.Data.SqlClient;

namespace InExcelOutExcel

{

public partial class ExcelToDB : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

FileSvr fileSvr = new FileSvr();

System.Data.DataTable dt = fileSvr.GetExcelDatatable("C:\\Users\\NewSpring\\Desktop\\Demo\\InExcelOutExcel\\InExcelOutExcel\\excel\\ExcelToDB.xlsx", "mapTable");

fileSvr.InsetData(dt);

}

}

class FileSvr

{

/// <summary>

/// Excel数据导入Datable

/// </summary>

/// <param name="fileUrl"></param>

/// <param name="table"></param>

/// <returns></returns>

public System.Data.DataTable GetExcelDatatable(string fileUrl, string table)

{

//office2007之前 仅支持.xls

//const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";

//支持.xls.xlsx,即包括office2010等版本的 HDR=Yes代表第一行是标题,不是数据;

const string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";

System.Data.DataTable dt = null;

//建立连接

OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));

try

{

//打开连接

if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)

{

conn.Open();

}

​

System.Data.DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);

//获取Excel的第一个Sheet名称

string sheetName = schemaTable.Rows[0]["TABLE_NAME"].ToString().Trim();

//查询sheet中的数据

string strSql = "select * from [" + sheetName + "]";

OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);

DataSet ds = new DataSet();

da.Fill(ds, table);

dt = ds.Tables[0];

return dt;

}

catch (Exception exc)

{

throw exc;

}

finally

{

conn.Close();

conn.Dispose();

}

}

/// <summary>

/// System.Data.DataTable导入数据到数据库

/// </summary>

/// <param name="dt"></param>

/// <returns></returns>

public int InsetData(System.Data.DataTable dt)

{

int i = 0;

string lng = "";

string lat = "";

string offsetLNG = "";

string offsetLAT = "";

foreach (DataRow dr in dt.Rows)

{

lng = dr["LNG"].ToString().Trim();

lat = dr["LAT"].ToString().Trim();

offsetLNG = dr["OFFSET_LNG"].ToString().Trim();

offsetLAT = dr["OFFSET_LAT"].ToString().Trim();

//sw = string.IsNullOrEmpty(sw) ? "null" : sw;

//kr = string.IsNullOrEmpty(kr) ? "null" : kr;

string strSql = string.Format("Insert into DBToExcel (LNG,LAT,OFFSET_LNG,OFFSET_LAT) Values ('{0}','{1}',{2},{3})", lng, lat, offsetLNG, offsetLAT);

string strConnection = ConfigurationManager.ConnectionStrings["ConnectionStr"].ToString();

SqlConnection sqlConnection = new SqlConnection(strConnection);

try

{

// SqlConnection sqlConnection = new SqlConnection(strConnection);

sqlConnection.Open();

SqlCommand sqlCmd = new SqlCommand();

sqlCmd.CommandText = strSql;

sqlCmd.Connection = sqlConnection;

SqlDataReader sqlDataReader = sqlCmd.ExecuteReader();

i++;

sqlDataReader.Close();

}

catch (Exception ex)

{

throw ex;

}

finally

{

sqlConnection.Close();

}

//if (opdb.ExcSQL(strSql))

// i++;

}

return i;

}

}

}

// Microsoft Access 2010 数据库引擎可再发行程序包

//https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=13255

​

​
using` `System; 

using` `System.Data; 

using` `System.Data.OleDb; 

using` `System.Data.SqlClient; 

using` `System.IO; 

using` `System.Text; 

using` `System.Web; 

using` `System.Web.UI; 

private` `DataTable  xsldata() 

       ``{ 

          ``if``(fuload.FileName == ``""``) 

           ``{ 

               ``lbmsg.Text = ``"请选择文件"``; 

               ``return` `null``; 

           ``} 

           ``string` `fileExtenSion; 

           ``fileExtenSion = Path.GetExtension(fuload.FileName); 

           ``if``(fileExtenSion.ToLower() != ``".xls"` `&& fileExtenSion.ToLower() != ``".xlsx"``) 

           ``{ 

               ``lbmsg.Text = ``"上传的文件格式不正确"``; 

               ``return` `null``; 

           ``} 

           ``try

           ``{ 

               ``string` `FileName = ``"App_Data/"` `+ Path.GetFileName(fuload.FileName); 

               ``if``(File.Exists(Server.MapPath(FileName))) 

               ``{ 

                   ``File.Delete(Server.MapPath(FileName)); 

               ``} 

               ``fuload.SaveAs(Server.MapPath(FileName)); 

               ``//HDR=Yes,这代表第一行是标题,不做为数据使用 ,如果用HDR=NO,则表示第一行不是标题,做为数据来使用。系统默认的是YES 

               ``string` `connstr2003 = ``"Provider=Microsoft.Jet.OLEDB.4.0;Data Source="` `+ Server.MapPath(FileName) + ``";Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'"``; 

               ``string` `connstr2007 = ``"Provider=Microsoft.ACE.OLEDB.12.0;Data Source="` `+ Server.MapPath(FileName) + ``";Extended Properties=\"Excel 12.0;HDR=YES\""``; 

               ``OleDbConnection conn; 

               ``if``(fileExtenSion.ToLower() == ``".xls"``) 

               ``{ 

                   ``conn = ``new` `OleDbConnection(connstr2003); 

               ``} 

               ``else

               ``{ 

                   ``conn = ``new` `OleDbConnection(connstr2007); 

               ``} 

               ``conn.Open(); 

               ``string` `sql = ``"select * from [Sheet1$]"``; 

               ``OleDbCommand cmd = ``new` `OleDbCommand(sql, conn); 

               ``DataTable dt = ``new` `DataTable(); 

               ``OleDbDataReader sdr = cmd.ExecuteReader(); 



               ``dt.Load(sdr); 

               ``sdr.Close(); 

               ``conn.Close(); 

               ``//删除服务器里上传的文件 

               ``if``(File.Exists(Server.MapPath(FileName))) 

               ``{ 

                   ``File.Delete(Server.MapPath(FileName)); 

               ``} 

               ``return` `dt; 

           ``} 

           ``catch``(Exception e) 

           ``{ 

               ``return` `null``; 

           ``} 

       ``} 



       ``protected` `void` `Btn_Export_Excel_To_DB_Click(``object` `sender, EventArgs e) 

       ``{ 

           ``try``{ 



               ``DataTable dt = xsldata(); 



               ``//dataGridView2.DataSource = ds.Tables[0]; 

               ``int` `errorcount = 0;``//记录错误信息条数 

               ``int` `insertcount = 0;``//记录插入成功条数 



               ``int` `updatecount = 0;``//记录更新信息条数 



               ``string` `strcon = ``"server=localhost;database=database1;uid=sa;pwd=sa"``; 

               ``SqlConnection conn = ``new` `SqlConnection(strcon);``//链接数据库 

               ``conn.Open(); 



               ``for``(``int` `i = 0; i < dt.Rows.Count; i++) 

               ``{ 

                   ``string` `Name = dt.Rows[i][0].ToString();``//dt.Rows[i]["Name"].ToString(); "Name"即为ExcelName列的表头 

                   ``string` `Sex = dt.Rows[i][1].ToString(); 

                   ``int` `Age = Convert.ToInt32(dt.Rows[i][2].ToString()); 

                   ``string` `Address = dt.Rows[i][3].ToString(); 

                   ``if``(Name != ``""` `&& Sex != ``""` `&& Age != 0 && Address != ``""``) 

                   ``{ 

                       ``SqlCommand selectcmd = ``new` `SqlCommand(``"select count(*) from users where Name='"` `+ Name + ``"' and Sex='"` `+ Sex + ``"' and Age='"` `+ Age + ``"' and Address="` `+ Address, conn); 

                       ``int` `count = Convert.ToInt32(selectcmd.ExecuteScalar()); 

                       ``if``(count > 0) 

                       ``{ 

                           ``updatecount++; 

                       ``} 

                       ``else

                       ``{ 

                           ``SqlCommand insertcmd = ``new` `SqlCommand(``"insert into users(Name,Sex,Age,Address) values('"` `+ Name + ``"','"` `+ Sex + ``"',"` `+ Age + ``",'"` `+ Address + ``"')"``, conn); 

                           ``insertcmd.ExecuteNonQuery(); 

                           ``insertcount++; 

                       ``} 

                   ``} 

                   ``else

                   ``{ 

                       ``errorcount++; 

                   ``} 

               ``} 

               ``Response.Write((insertcount + ``"条数据导入成功!"` `+ updatecount + ``"条数据重复!"` `+ errorcount + ``"条数据部分信息为空没有导入!"``)); 

           ``} 

           ``catch``(Exception ex) 

           ``{ 



           ``} 

       ``}

1.使用定时器执行任务:

//定义Timer System.Timers.Timer timer; /// <summary> /// 初始化Timer控件 /// </summary> private void InitTimer() { //设置定时间隔(毫秒为单位) int interval = 3000; timer = new System.Timers.Timer(interval); //设置执行一次(false)还是一直执行(true) timer.AutoReset = true; //设置是否执行System.Timers.Timer.Elapsed事件 timer.Enabled = true; //绑定Elapsed事件 timer.Elapsed += new System.Timers.ElapsedEventHandler(TimerUp); //开始 timer.Start(); }

/// <summary> /// Timer类执行定时到点事件 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void TimerUp(object sender, System.Timers.ElapsedEventArgs e) { try { readDataFromAcess(); WriteToDb();

      }

       catch (Exception ex)

      {

           MessageBox.Show("执行定时到点事件失败:" + ex.Message);

      }

  }

private void readDataFromAcess() { //label2.Text = String.Empty; try { using (OleDbConnection conn = new OleDbConnection( "Provider = Microsoft.Ace.OLEDB.12.0;Data Source = C:\SintonInstruments\BulkLifetimeSummaryData\Summary.accdb")) { conn.Open();//要先打开连接 using (OleDbCommand cmd = conn.CreateCommand()) //创建小货车 cmd { //参数的使用 // 获取或设置 SQL 语句或存储的过程以在数据源中执行。 cmd.CommandText = "select GuestsID, Name, Time, Date, EstBulkLifetime from SummaryData where GuestsID = (select max(GuestsID) from SummaryData);"; //cmd.Parameters.Add(new SqlParameter("@rank", 2)); //因为SqlDataReader实现了IDisposable接口,释放对象资源的接口是IDisposable using (OleDbDataReader reader = cmd.ExecuteReader()) { //查询到结果放在数据库中没有放到客户端中,以后可以用DataSet处理 while (reader.Read()) { temp = double.Parse(reader[4].ToString()); //label2.Text = "OK"; //string name = (string)reader.GetString(0); //MessageBox.Show(name); } } } } } catch(Exception e) { MessageBox.Show(e.Message); } }

//向数据库中写入数据 private void writeToDb() { if(Invaild()) //晶编等信息都已维护 { string selectSql = @"{?=call longimes.LJ_MES_AGE_CHECKED_SET.update_data_for_lifetime2('"

                    + this.txb_code.Text.Trim() + "','"

                                            + this.label1.Text + "','"

                    + 

                                            + this.label1.Text + + _location + "','"

                                                                      + this.txb_mode.Text + "','"

                                                                          + this.txb_prod.Text + "','"

                                                                          + this.lab_isQua.Text + "','"

                                                                          + this.cmbWorkshop.Text.Trim() + "')}";

                                            string str = (string)DatabaseAccessService.execute(selectSql, ReturnType.STRING);

                                          Mes.Core.ApplicationObject.PkgReturnValue rv = new Mes.Core.ApplicationObject.PkgReturnValue(str);

                                          if (rv.IsExecuteFail)

                                          {

                                                          this.toolStripStatusLabel1.Text = DateTime.Now.ToString() + " 数据录入不成功";

                                                          MessageBox.Show("数据录入不成功!");

                                                          Mes.Core.Service.MessageService.ShowMessage(rv.Message);

                                                          return;

                                          }

                                          else

                                          {

                                                          this.toolStripStatusLabel1.Text = DateTime.Now.ToString() + " 数据录入成功";

                                          //   foreach (Control rab in groupBoxEx1.Controls)

                                          //   {

                                          //       if (rab is RadioButton)

                                        //       {

                                        //           if ((rab as RadioButton).Checked == true)

                                        //               (rab as RadioButton).BackColor = Color.Green;

                                        //       }

                                        //   }

                                                  }

                                    }

                                                      }

5.学生管理系统视屏

https://study.163.com/course/courseLearn.htm?courseId=1004094049#/learn/video?lessonId=1047972255&courseId=1004094049 网易云课堂

判断文本框中输入内容和文件夹中Excel表名对应代码。

using System.IO; IF(File.Exists(指定路径+"\"+文件框输入的EXCEL名称+".xlsx") || File.Exists(指定路径+"\"+文件框输入的EXCEL名称+".xls") )//支持.xlsx.xls { //存在 } else { //不存在 }

//根据晶体编码获取产品规格代码:

private string GetInfoByCrystal(string p_crystalno) { string selectOp = @"{?=call longimes.lj_mes_oxygen_carbon_data.get_oxygencarbondata_bycrystal('" + p_crystalno + "')}"; return (string)DatabaseAccessService.execute(selectOp, ReturnType.STRING); }

//与之相对应的plsql代码

FUNCTION GET_OXYGENCARBONDATA_BYCRYSTAL(p_crystal IN VARCHAR2) RETURN VARCHAR2 IS X_RET VARCHAR2(100); BEGIN -- OPEN X_RET FOR SELECT t.Stad_Production ||','|| CASE SUBSTR(t.Crystal_Encoding, 3, 1) WHEN 'X' THEN 'P' WHEN 'P' THEN 'N' WHEN 'S' THEN 'S' ELSE '未知' END ||','|| s.WORKSHOP INTO X_RET FROM LJ_MES_MAOBANG_CHECKED t LEFT JOIN LJ_MES_SINGLESTOVE_INFO s ON SUBSTR(t.Crystal_Encoding, 6, 3) = REPLACE(s.Stove_Number, 'DJL0', '') WHERE t.STATE = 'VALID' AND s.STATE = 'VALID' AND CRYSTAL_ENCODING = substr(p_crystal,1,11); RETURN X_RET; END;

LJMESOCDataInput --trunc(v-val_o,[2])对输入的数字进行限定处理

//查询拼接语句

 

string sql = "select t.k_id,t.package_id,t.big_box_id,t.print_status from longimes.LJ_MES_QP_INSTORAGE t where 1=1";

            if (!string.IsNullOrEmpty(this.tbBracket.Text))

            {

                sql += " and t.package_id like '%" + this.tbBracket.Text + "%'";

            }

            if (!string.IsNullOrEmpty(this.tbBigBoxCode.Text))

            {

                sql += " and t.big_box_id like '%" + this.tbBigBoxCode.Text + "%'";

            }

            sql += "and t.work_shop='" + getWorkShop() + "'";

lj_mes_lpceshi

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章