亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mrbaseinf.cs

?? 一個簡單的基于WEB的asp.net+sql server開發的人事管理系統
?? CS
?? 第 1 頁 / 共 3 頁
字號:
using System;
using System.Data;
using System.Data.SqlClient;


using qminoa.Common.Data;

namespace qminoa.DA
{
	public class MrBaseInf :IDisposable
	{
		private string conStr ;
		private SqlConnection con ;
		private SqlDataAdapter commandAdp ;

		private string paramChg(string str)
		{
			str = "@"+str;
			return str;
		}

		public DataSet GetEmpConData_By_ConID(int conID)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "GetEmpConInfByConID";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			SqlParameter param = new SqlParameter(paramChg(EmpConData.CONID_FIELD),SqlDbType.Int);
			param.Value = conID;
			command.Parameters.Add(param);

			commandAdp.SelectCommand = command;
			DataSet data = new DataSet();
			try
			{
				commandAdp.Fill(data);
			}
			catch(Exception ex)
			{
				throw new ApplicationException(ex.ToString());
			}
			return data;
		}

		public bool UpdateMrContact(EmpConData empData)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "UpdateMrContact";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			command.Parameters.Add(paramChg(EmpConData.CONID_FIELD),SqlDbType.Int);
			command.Parameters.Add(paramChg(EmpConData.CATETORY_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.FDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpConData.TDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpConData.POSILEVL_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.SALALEVL_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.ANNSALA_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.STATUS_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.CONNOTE_FIELD),SqlDbType.Text);
			command.Parameters[paramChg(EmpConData.CONID_FIELD)].SourceColumn = EmpConData.CONID_FIELD;
			command.Parameters[paramChg(EmpConData.CATETORY_FIELD)].SourceColumn = EmpConData.CATETORY_FIELD;
			command.Parameters[paramChg(EmpConData.FDATE_FIELD)].SourceColumn = EmpConData.FDATE_FIELD;
			command.Parameters[paramChg(EmpConData.TDATE_FIELD)].SourceColumn = EmpConData.TDATE_FIELD;
			command.Parameters[paramChg(EmpConData.POSILEVL_FIELD)].SourceColumn = EmpConData.POSILEVL_FIELD;
			command.Parameters[paramChg(EmpConData.SALALEVL_FIELD)].SourceColumn = EmpConData.SALALEVL_FIELD;
			command.Parameters[paramChg(EmpConData.ANNSALA_FIELD)].SourceColumn = EmpConData.ANNSALA_FIELD;
			command.Parameters[paramChg(EmpConData.STATUS_FIELD)].SourceColumn = EmpConData.STATUS_FIELD;
			command.Parameters[paramChg(EmpConData.CONNOTE_FIELD)].SourceColumn = EmpConData.CONNOTE_FIELD;
			
			commandAdp.UpdateCommand = command;
			commandAdp.Update(empData,EmpConData.EMPCONTACT_TABLE_NAME);

			if(empData.HasErrors)
			{
				empData.Tables[EmpBaseData.EMP_TABLE_NAME].GetErrors()[0].ClearErrors();
				return false;
			}
			else
			{
				empData.AcceptChanges();
				return true;
			}
		}

		public bool InsertMrContact(EmpConData empData)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "InsertMrContact";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			command.Parameters.Add(paramChg(EmpBaseData.EMPID_FIELD),SqlDbType.Int);
			command.Parameters.Add(paramChg(EmpConData.CATETORY_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.FDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpConData.TDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpConData.POSILEVL_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.SALALEVL_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.ANNSALA_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.STATUS_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpConData.CONNOTE_FIELD),SqlDbType.Text);
			command.Parameters[paramChg(EmpBaseData.EMPID_FIELD)].SourceColumn = EmpBaseData.EMPID_FIELD;
			command.Parameters[paramChg(EmpConData.CATETORY_FIELD)].SourceColumn = EmpConData.CATETORY_FIELD;
			command.Parameters[paramChg(EmpConData.FDATE_FIELD)].SourceColumn = EmpConData.FDATE_FIELD;
			command.Parameters[paramChg(EmpConData.TDATE_FIELD)].SourceColumn = EmpConData.TDATE_FIELD;
			command.Parameters[paramChg(EmpConData.POSILEVL_FIELD)].SourceColumn = EmpConData.POSILEVL_FIELD;
			command.Parameters[paramChg(EmpConData.SALALEVL_FIELD)].SourceColumn = EmpConData.SALALEVL_FIELD;
			command.Parameters[paramChg(EmpConData.ANNSALA_FIELD)].SourceColumn = EmpConData.ANNSALA_FIELD;
			command.Parameters[paramChg(EmpConData.STATUS_FIELD)].SourceColumn = EmpConData.STATUS_FIELD;
			command.Parameters[paramChg(EmpConData.CONNOTE_FIELD)].SourceColumn = EmpConData.CONNOTE_FIELD;
			
			commandAdp.InsertCommand = command;

			commandAdp.Update(empData,EmpConData.EMPCONTACT_TABLE_NAME);

			if(empData.HasErrors)
			{
				empData.Tables[EmpBaseData.EMP_TABLE_NAME].GetErrors()[0].ClearErrors();
				return false;
			}
			else
			{
				empData.AcceptChanges();
				return true;
			}
		}

		public bool DeleteMrContact(int conID)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "DeleteMrContact";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			SqlParameter param = new SqlParameter(paramChg(EmpConData.CONID_FIELD),SqlDbType.Int);
			param.Value = conID;
			command.Parameters.Add(param);

			con.Open();
			int result = command.ExecuteNonQuery();
			con.Close();
			if(result>0)
			{
				return true;
			}
			else
			{
				return false;
			}

		}

		public DataSet GetEmpConData(int empID)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "GetEmpConInf";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			SqlParameter param = new SqlParameter(paramChg(EmpBaseData.EMPID_FIELD),SqlDbType.Int);
			param.Value = empID;
			command.Parameters.Add(param);

			commandAdp.SelectCommand = command;
			DataSet data = new DataSet();
			try
			{
				commandAdp.Fill(data);
			}
			catch(Exception ex)
			{
				throw new ApplicationException(ex.ToString());
			}
			return data;

		}

		public bool InsertMrArchive(EmpArcData empData)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "InsertMrArchive";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			command.Parameters.Add(paramChg(EmpBaseData.EMPID_FIELD),SqlDbType.Int);
			command.Parameters.Add(paramChg(EmpArcData.CATETORY_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.FDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpArcData.TDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpArcData.BRANAME_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.DEPNAME_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.POSITION_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.REASON_FIELD),SqlDbType.Text);
			command.Parameters.Add(paramChg(EmpArcData.ARCNOTE_FIELD),SqlDbType.Text);

			command.Parameters[paramChg(EmpBaseData.EMPID_FIELD)].SourceColumn = EmpBaseData.EMPID_FIELD;
			command.Parameters[paramChg(EmpArcData.CATETORY_FIELD)].SourceColumn = EmpArcData.CATETORY_FIELD;
			command.Parameters[paramChg(EmpArcData.FDATE_FIELD)].SourceColumn = EmpArcData.FDATE_FIELD;
			command.Parameters[paramChg(EmpArcData.TDATE_FIELD)].SourceColumn = EmpArcData.TDATE_FIELD;
			command.Parameters[paramChg(EmpArcData.BRANAME_FIELD)].SourceColumn = EmpArcData.BRANAME_FIELD;
			command.Parameters[paramChg(EmpArcData.DEPNAME_FIELD)].SourceColumn = EmpArcData.DEPNAME_FIELD;
			command.Parameters[paramChg(EmpArcData.POSITION_FIELD)].SourceColumn = EmpArcData.POSITION_FIELD;
			command.Parameters[paramChg(EmpArcData.REASON_FIELD)].SourceColumn = EmpArcData.REASON_FIELD;
			command.Parameters[paramChg(EmpArcData.ARCNOTE_FIELD)].SourceColumn = EmpArcData.ARCNOTE_FIELD;

			commandAdp.InsertCommand = command;

			commandAdp.Update(empData,EmpArcData.EMPARCHIVE_TABLE_NAME);

			if(empData.HasErrors)
			{
				empData.Tables[EmpBaseData.EMP_TABLE_NAME].GetErrors()[0].ClearErrors();
				return false;
			}
			else
			{
				empData.AcceptChanges();
				return true;
			}
		}

		public bool UpdateMrArchive(EmpArcData empData)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "UpdateMrArchive";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			command.Parameters.Add(paramChg(EmpArcData.ARCID_FIELD),SqlDbType.Int);
			command.Parameters.Add(paramChg(EmpArcData.CATETORY_FIELD),SqlDbType.VarChar)  ;
				command.Parameters.Add(paramChg(EmpArcData.FDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpArcData.TDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpArcData.BRANAME_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.DEPNAME_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.POSITION_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpArcData.REASON_FIELD),SqlDbType.Text);
			command.Parameters.Add(paramChg(EmpArcData.ARCNOTE_FIELD),SqlDbType.Text);
			//
			//
			//
			command.Parameters[paramChg(EmpArcData.ARCID_FIELD)].SourceColumn = EmpArcData.ARCID_FIELD;
			command.Parameters[paramChg(EmpArcData.CATETORY_FIELD)].SourceColumn = EmpArcData.CATETORY_FIELD;
			command.Parameters[paramChg(EmpArcData.FDATE_FIELD)].SourceColumn = EmpArcData.FDATE_FIELD;
			command.Parameters[paramChg(EmpArcData.TDATE_FIELD)].SourceColumn = EmpArcData.TDATE_FIELD;
			command.Parameters[paramChg(EmpArcData.BRANAME_FIELD)].SourceColumn = EmpArcData.BRANAME_FIELD;
			command.Parameters[paramChg(EmpArcData.DEPNAME_FIELD)].SourceColumn = EmpArcData.DEPNAME_FIELD;
			command.Parameters[paramChg(EmpArcData.POSITION_FIELD)].SourceColumn = EmpArcData.POSITION_FIELD;
			command.Parameters[paramChg(EmpArcData.REASON_FIELD)].SourceColumn = EmpArcData.REASON_FIELD;
			command.Parameters[paramChg(EmpArcData.ARCNOTE_FIELD)].SourceColumn = EmpArcData.ARCNOTE_FIELD;

			commandAdp.UpdateCommand = command;

			commandAdp.Update(empData,EmpArcData.EMPARCHIVE_TABLE_NAME);

			if(empData.HasErrors)
			{
				empData.Tables[EmpBaseData.EMP_TABLE_NAME].GetErrors()[0].ClearErrors();
				return false;
			}
			else
			{
				empData.AcceptChanges();
				return true;
			}
		}

		public DataSet GetEmpArcData_By_ArcID(int arcID)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "GetEmpArcInfByArcID";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			SqlParameter param = new SqlParameter(paramChg(EmpArcData.ARCID_FIELD),SqlDbType.Int);
			param.Value = arcID;
			command.Parameters.Add(param);

			commandAdp.SelectCommand = command;
			DataSet data = new DataSet();
			try
			{
				commandAdp.Fill(data);
			}
			catch(Exception ex)
			{
				throw new ApplicationException(ex.ToString());
			}
			return data;
		}

		public bool DeleteMrArchive(int arcID)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "DeleteMrArchive";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			SqlParameter param = new SqlParameter(paramChg(EmpArcData.ARCID_FIELD),SqlDbType.Int);
			param.Value = arcID;
			command.Parameters.Add(param);

			con.Open();
			int result = command.ExecuteNonQuery();
			con.Close();
			if(result>0)
			{
				return true;
			}
			else
			{
				return false;
			}
		}

		public bool UpdateMrVita(EmpVisaData empData)
		{
			SqlCommand command = new SqlCommand();
			command.CommandText = "UpdateMrVita";
			command.CommandType = CommandType.StoredProcedure;
			command.Connection = con;

			command.Parameters.Add(paramChg(EmpVisaData.VISAID_FIELD),SqlDbType.Int);
			command.Parameters.Add(paramChg(EmpVisaData.FDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpVisaData.TDATE_FIELD),SqlDbType.DateTime);
			command.Parameters.Add(paramChg(EmpVisaData.COMMPANY_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpVisaData.DEPNAME_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpVisaData.POSITION_FIELD),SqlDbType.VarChar);
			command.Parameters.Add(paramChg(EmpVisaData.VISANOTE_FIELD),SqlDbType.Text);
			//
			//
			//
			command.Parameters[paramChg(EmpVisaData.VISAID_FIELD)].SourceColumn = EmpVisaData.VISAID_FIELD;
			command.Parameters[paramChg(EmpVisaData.FDATE_FIELD)].SourceColumn = EmpVisaData.FDATE_FIELD;
			command.Parameters[paramChg(EmpVisaData.TDATE_FIELD)].SourceColumn = EmpVisaData.TDATE_FIELD;
			command.Parameters[paramChg(EmpVisaData.COMMPANY_FIELD)].SourceColumn = EmpVisaData.COMMPANY_FIELD;
			command.Parameters[paramChg(EmpVisaData.DEPNAME_FIELD)].SourceColumn = EmpVisaData.DEPNAME_FIELD;
			command.Parameters[paramChg(EmpVisaData.POSITION_FIELD)].SourceColumn = EmpVisaData.POSITION_FIELD;
			command.Parameters[paramChg(EmpVisaData.VISANOTE_FIELD)].SourceColumn = EmpVisaData.VISANOTE_FIELD;

			commandAdp.UpdateCommand = command;

			commandAdp.Update(empData,EmpVisaData.EMPVISA_TABLE_NAME);

			if(empData.HasErrors)
			{
				empData.Tables[EmpBaseData.EMP_TABLE_NAME].GetErrors()[0].ClearErrors();
				return false;
			}
			else
			{
				empData.AcceptChanges();
				return true;
			}


		}

		public bool InsertMrVita(EmpVisaData empData)
		{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡视频在线观看| 中文字幕亚洲一区二区va在线| 亚洲一线二线三线视频| 91玉足脚交白嫩脚丫在线播放| 国产精品久久久久久久久快鸭 | 成人激情动漫在线观看| 精品国产乱码久久久久久夜甘婷婷 | 91免费观看在线| 一区二区三区在线观看网站| 欧美日韩一区二区三区视频| 亚洲成人久久影院| 日韩一区二区精品葵司在线| 国产精品一级在线| 国产精品成人一区二区艾草| 色国产综合视频| 人人超碰91尤物精品国产| 精品福利一区二区三区免费视频| 国产揄拍国内精品对白| 中文字幕在线不卡一区二区三区| 日本乱码高清不卡字幕| 另类小说一区二区三区| 国产精品久久毛片av大全日韩| 91欧美一区二区| 视频一区视频二区中文| 中文在线免费一区三区高中清不卡| 暴力调教一区二区三区| 亚洲一级在线观看| 久久久久久久国产精品影院| jizz一区二区| 日本网站在线观看一区二区三区| 欧美精彩视频一区二区三区| 色999日韩国产欧美一区二区| 免费av成人在线| 国产精品福利av| 欧美高清精品3d| 成人av在线资源| 日韩电影一区二区三区四区| 国产精品美女久久久久久| 5858s免费视频成人| 成人免费视频一区| 日韩成人免费在线| 亚洲免费视频中文字幕| 精品久久久久久久久久久久包黑料 | 麻豆成人综合网| 亚洲精选视频在线| 久久综合色综合88| 337p亚洲精品色噜噜噜| 成人av电影在线播放| 丝袜亚洲精品中文字幕一区| 亚洲日本va在线观看| 精品成人在线观看| 欧美伊人久久大香线蕉综合69| 国产精品一区二区在线观看网站| 午夜精品久久久久久| 亚洲精品久久嫩草网站秘色| 国产女人水真多18毛片18精品视频| 7777精品伊人久久久大香线蕉的| 色婷婷亚洲一区二区三区| 国产精品一二三在| 蜜芽一区二区三区| 五月综合激情婷婷六月色窝| 亚洲激情自拍视频| 中文字幕一区二区三区在线播放| 日韩欧美国产一二三区| 欧美日韩免费高清一区色橹橹| 91视频com| 99精品视频在线观看免费| 国产在线精品免费| 久久成人免费网站| 精品一区二区三区视频在线观看| 丝袜诱惑亚洲看片| 日本女优在线视频一区二区| 日韩精品色哟哟| 欧美aaa在线| 麻豆中文一区二区| 另类小说欧美激情| 麻豆免费精品视频| 国产主播一区二区三区| 国产一区二区精品久久99| 紧缚奴在线一区二区三区| 捆绑变态av一区二区三区| 日韩av中文字幕一区二区| 日日摸夜夜添夜夜添国产精品| 污片在线观看一区二区| 免费观看91视频大全| 美女视频网站久久| 国模冰冰炮一区二区| 国产成人精品一区二| 99久久精品免费看国产| 色94色欧美sute亚洲线路一久| 91亚洲精华国产精华精华液| 99热在这里有精品免费| 91网上在线视频| 777亚洲妇女| 久久先锋影音av| 国产精品毛片大码女人| 一区二区三区在线高清| 亚洲国产日韩在线一区模特| 蜜桃精品视频在线| 激情综合亚洲精品| 9l国产精品久久久久麻豆| 在线亚洲免费视频| 欧美成人a视频| 国产精品网站导航| 亚洲一区二区在线视频| 青青草国产精品97视觉盛宴| 国产高清精品在线| 欧美视频在线观看一区| 精品国产制服丝袜高跟| 国产精品国产三级国产普通话蜜臀 | 欧美成人精精品一区二区频| 国产欧美综合色| 亚洲一区二区欧美日韩| 国模少妇一区二区三区| 一本久道久久综合中文字幕| 欧美一区二区三区视频免费播放| 久久精品欧美一区二区三区不卡| 亚洲区小说区图片区qvod| 日本不卡一区二区| 91免费视频网址| 久久综合九色综合欧美就去吻| 中文字幕中文字幕中文字幕亚洲无线| 亚洲一区二区三区四区中文字幕| 狠狠色丁香婷综合久久| 色国产综合视频| 中文字幕高清不卡| 日本欧美加勒比视频| 一本久久综合亚洲鲁鲁五月天 | 欧美日韩三级在线| 国产精品美女久久久久av爽李琼| 五月天激情综合网| 成人动漫一区二区在线| 日韩视频123| 亚洲精品自拍动漫在线| 国产很黄免费观看久久| 欧美一区二区啪啪| 亚洲欧美日韩国产一区二区三区 | 日本一区二区久久| 蜜桃久久久久久| 欧美日韩你懂的| 亚洲精选免费视频| 成人av在线播放网址| 欧美本精品男人aⅴ天堂| 亚洲国产一区在线观看| 91美女片黄在线| 国产欧美日韩麻豆91| 狠狠久久亚洲欧美| 7777精品伊人久久久大香线蕉超级流畅 | 欧美午夜精品一区二区蜜桃| 日本一区二区在线不卡| 久久精品久久综合| 欧美二区在线观看| 亚洲一区二区三区免费视频| aaa国产一区| 中文字幕一区二区三区精华液| 国产一区不卡视频| 欧美va亚洲va香蕉在线| 日韩av电影天堂| 欧美一卡二卡三卡| 日产国产欧美视频一区精品| 欧美电影一区二区| 石原莉奈在线亚洲二区| 欧美日韩精品高清| 五月天久久比比资源色| 在线不卡免费av| 爽好多水快深点欧美视频| 欧美日韩视频在线第一区| 亚洲成人av在线电影| 欧美日本国产视频| 日韩av电影免费观看高清完整版 | 婷婷久久综合九色综合绿巨人| 色哟哟精品一区| 一区二区三区日韩在线观看| 日本高清不卡视频| 亚洲一区二区免费视频| 欧美美女黄视频| 美女网站视频久久| 久久久欧美精品sm网站| 国产aⅴ精品一区二区三区色成熟| 国产亚洲精品超碰| 粉嫩蜜臀av国产精品网站| 国产精品看片你懂得| 91免费国产在线| 天堂成人国产精品一区| 精品国产一区二区三区忘忧草 | 国产精品传媒入口麻豆| 91国产精品成人| 日韩在线一区二区| 精品久久久久99| www.激情成人| 亚洲一区精品在线| 日韩欧美亚洲一区二区| 国产精品综合久久| 综合久久国产九一剧情麻豆| 欧美日韩久久不卡| 国产精品一二三四区| 亚洲影视在线观看| 欧美成人在线直播| 91亚洲国产成人精品一区二三 | 亚洲精品乱码久久久久久久久 |