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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? class_odbc.prg

?? 用VFP訪問數(shù)據(jù)庫(kù)的odbc代碼
?? PRG
字號(hào):
DEFINE CLASS ODBC as Custom   
   m_dbhandle=-1
   m_error=""
   m_trans=1
   m_cursor = ""
   m_db = ""
   FUNCTION INIT
   	  this.m_dbhandle = -1
   	  this.m_error = ""
   	  this.m_trans = 1
   ENDFUNC 
   FUNCTION destroy 
	  this.Close()
   ENDFUNC 
   FUNCTION close
   	  IF this.m_dbhandle!=-1
   	     IF this.m_trans = 2
   	     	this.Rollback()
   	     ENDIF 
   	  	 SQLDISCONNECT(this.m_dbhandle)
   	  ENDIF  
   	  m_dbhandle = -1
   ENDFUNC 
   FUNCTION open
      PARAMETERS m_dns, m_uid, m_pass
      this.close()
      this.m_dbhandle = SQLCONNECT(m_dns,m_uid,m_pass)
      IF this.m_dbhandle=-1
      	  AERROR(err)
      	  this.m_error = err[1,2]
      	  RETURN .F.
      ELSE 
      	  RETURN .T.
      ENDIF 
   ENDFUNC 
   FUNCTION prepare
   	  PARAMETERS m_sqlstr,m_cursor,m_to_db
   	  LOCAL m_result
   	  m_db = ""
   	  IF VARTYPE(m_cursor)!='C'
	   	  m_result = SQLPREPARE(this.m_dbhandle,m_sqlstr)
	  ELSE 
	  	  m_result = SQLPREPARE(this.m_dbhandle,m_sqlstr,m_cursor)
	  	  IF m_result!=-1 AND VARTYPE(m_to_db)='C'
	  	    this.m_cursor = m_cursor 
	  	  	this.m_db = m_to_db
	  	  ENDIF 
	  ENDIF 
      IF m_result=-1
      	  AERROR(err)
      	  this.m_error = err[1,2]
      	  RETURN .F.
      ELSE 
      	  RETURN .T.
      ENDIF 
   ENDFUNC 
   FUNCTION exec
   	  PARAMETERS m_sqlstr,m_cursor,m_to_db
   	  LOCAL m_result,m_tcur,m_tdb
   	  IF  VARTYPE(m_sqlstr)!='C'
        m_result = SQLEXEC(this.m_dbhandle)
   	    IF m_result!=-1 AND !EMPTY(this.m_db)
   	        m_tcur = this.m_cursor 
   	        m_tdb = this.m_db
   	        IF FILE("&m_tcur..dbf")
   	        	DROP TABLE &m_tcur.
   	        ENDIF 
   	    	COPY TO &m_tcur. DATABASE &m_tdb. 
   	    ENDIF 
   	  ELSE 
   	    IF VARTYPE(m_cursor)!='C'
	   	    m_result = SQLEXEC(this.m_dbhandle,m_sqlstr)
	    ELSE 
	  	    m_result = SQLEXEC(this.m_dbhandle,m_sqlstr,m_cursor)
	  	    IF m_result!=-1 AND VARTYPE(m_to_db)='C'
	   	        IF FILE("&m_cursor..dbf")
   		        	DROP TABLE &m_cursor.
   	    	    ENDIF 
	  	    	COPY TO &m_cursor. DATABASE &m_to_db. 
	  	    ENDIF 
	    ENDIF
	  ENDIF  
      IF m_result=-1
      	  AERROR(err)
      	  this.m_error = err[1,2]
      	  RETURN .F.
      ELSE 
      	  RETURN .T.
      ENDIF       
   ENDFUNC 
   FUNCTION AutoTrans
   	  SQLSETPROP(this.m_dbhandle,"Transactions",1)
   	  m_trans = 1
   ENDFUNC 
   FUNCTION beginTrans
      SQLSETPROP(this.m_dbhandle,"Transactions",2)
      m_trans = 2
   ENDFUNC 
   FUNCTION Commit
      SQLCOMMIT(this.m_dbhandle)
   ENDFUNC 
   FUNCTION Rollback
      SQLROLLBACK(this.m_dbhandle)
   ENDFUNC 
   FUNCTION CreateTable
      PARAMETERS m_tableName, m_alia
      PRIVATE m_result
      result = gen_table_sql_from_alia(m_tableName,m_alia)
      IF NOT this.exec(m_result)
      	RETURN .F.
      ELSE 
      	RETURN .T.
      ENDIF 
   ENDFUNC 
   FUNCTION AppendFrom
      PARAMETERS m_tableName, m_alia, m_trans_rows
      LOCAL m_sqlstr,m_nn 
      IF VARTYPE(m_trans_rows)!='N'
      	m_trans_rows = 0
      ENDIF 
      IF m_trans_rows>0
      	 this.beginTrans()
      ENDIF 
      SELECT &m_alia.
      IF NOT this.exec("select * from &m_tableName. where rownum<2")
      	RETURN .F.
      ENDIF 
      m_sqlstr = "insert into &m_tableName. values ("
   	  m_sqlstr = m_sqlstr + "?"+FIELD(m_nn)
      FOR m_nn = 2 TO FCOUNT()
      	m_sqlstr = m_sqlstr + ", ?"+FIELD(m_nn)
      ENDFOR 
      m_sqlstr = m_sqlstr +")"
      IF NOT this.prepare(m_sqlstr)
      	 RETURN .F.
      ENDIF 
      SCAN 
      		SCATTER MEMVAR 
      		IF NOT this.exec()
      			RETURN .F.
      		ENDIF 
      		IF m_trans_rows>0
      			IF RECNO()%m_trans_rows = 0
      				this.Commit()
      				WAIT WINDOW "Append:"+STR(RECNO()) NOWAIT 
      			ENDIF 
      		ELSE 
      			IF RECNO()%500 = 0
      				WAIT WINDOW "Append:"+STR(RECNO()) NOWAIT 
      			ENDIF 
      		ENDIF 
      ENDSCAN 
      IF m_trans_rows>0
      	this.Commit()
      ENDIF 
      RETURN .T.
   ENDFUNC 
   FUNCTION gen_table_sql_from_alia
		parameter m_table_name,m_alia
		private m_result
		select &m_alia.
		copy stru exten to _tmp_ext
		m_result = "create table &m_table_name. ("
		sele 0
		use _tmp_ext
		scan 
			m_result = m_result + alltrim(field_name)+" "
			do case
			case field_type='C'
				m_result = m_result + "char("+alltrim(str(field_len))+") "+iif(field_null," NULL ","")
			case field_type='N'
				m_result = m_result + "numeric("+alltrim(str(field_len))+","+alltrim(str(field_dec))+") "+iif(field_null," NULL ","")
			CASE field_type='I'
				m_result = m_result + "Integer "+IIF(field_null," NULL ", "")
			CASE field_type='B'
				m_result = m_result + "Double "+IIF(field_null," NULL ", "")
			CASE field_type='F'
				m_result = m_result + "Float "+IIF(field_null," NULL ", "")
			CASE field_type='D'
				m_result = m_result + "date " +IIF(field_null," NULL ", "")
			case field_type='T'
				m_result = m_result + "time "+iif(field_null," NULL ","")
			case field_type='M'
				m_result = m_result + "varchar(1000) "+iif(field_null," NULL ","")
			other 
				messagebox("error type:"+field_type)
				return ""
			endcase 
			if recno()<reccount()
				m_result = m_result +","
			endif 
		endscan 
		use
		erase _tmp_ext.dbf
		m_result = m_result+")"
		return m_result
   ENDFUNC 
ENDDEFINE 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色呦呦一区二区三区| 国产日韩欧美激情| 欧美日韩一区二区三区免费看| 成人免费av在线| 福利一区二区在线| 国产美女在线观看一区| 国产伦精品一区二区三区免费迷| 男女视频一区二区| 裸体健美xxxx欧美裸体表演| 天天影视网天天综合色在线播放 | 自拍偷拍亚洲激情| 中文字幕在线视频一区| 国产精品高潮呻吟久久| 亚洲免费在线视频| 亚洲激情网站免费观看| 亚洲午夜成aⅴ人片| 亚洲综合在线免费观看| 亚洲午夜久久久久久久久电影院| 一区二区三区美女| 香蕉成人啪国产精品视频综合网| 五月天欧美精品| 免费成人美女在线观看| 美女视频黄a大片欧美| 精品一区在线看| 国产69精品一区二区亚洲孕妇| 国产成人鲁色资源国产91色综| 福利电影一区二区| 92国产精品观看| 欧美三片在线视频观看| 欧美精品一二三四| 4438亚洲最大| www国产亚洲精品久久麻豆| 国产精品丝袜一区| 亚洲高清不卡在线观看| 奇米在线7777在线精品| 国产资源在线一区| 97久久久精品综合88久久| 欧美曰成人黄网| 日韩精品一区二| 中文字幕一区二区视频| 亚洲一区二区视频在线| 免费在线观看成人| 成人免费毛片a| 欧美揉bbbbb揉bbbbb| 精品国产区一区| 中文字幕一区二区三区四区不卡 | 一本大道av一区二区在线播放| 欧美人动与zoxxxx乱| 精品成a人在线观看| 国产精品乱码一区二区三区软件| 一区二区三区蜜桃| 国产乱淫av一区二区三区| 在线观看www91| 久久亚洲综合色一区二区三区 | 成人av电影观看| 欧美疯狂性受xxxxx喷水图片| 国产女同性恋一区二区| 亚洲午夜在线视频| 国产成人精品免费网站| 欧美日本乱大交xxxxx| 国产欧美日韩综合| 日韩av电影免费观看高清完整版 | 91精品视频网| 亚洲男女一区二区三区| 国内精品视频一区二区三区八戒| 91视频com| 欧美zozo另类异族| 日韩亚洲国产中文字幕欧美| 中文字幕一区三区| 日本aⅴ亚洲精品中文乱码| 国产一区二区看久久| 色哟哟亚洲精品| 精品国产一区二区国模嫣然| 中文字幕在线观看一区二区| 亚洲一区二区三区四区不卡| 风间由美性色一区二区三区| 欧美少妇性性性| 国产亚洲欧美一级| 亚洲成a人v欧美综合天堂下载| 国产一区二区三区国产| 91国产丝袜在线播放| 欧美变态口味重另类| 亚洲精品菠萝久久久久久久| 秋霞电影一区二区| 成人av在线播放网站| 日韩一区二区三区电影| 亚洲欧美偷拍三级| 久久97超碰国产精品超碰| 欧美主播一区二区三区| 日韩欧美一级精品久久| 亚洲精品一二三四区| 国产一区二区中文字幕| 欧美老女人在线| 亚洲天天做日日做天天谢日日欢 | 99久久婷婷国产综合精品电影 | 91小视频在线观看| 国产亚洲欧美中文| 蜜桃久久精品一区二区| 欧美在线一区二区三区| 日本一区二区三区高清不卡| 麻豆成人久久精品二区三区红| 在线观看网站黄不卡| 国产精品丝袜在线| 国产综合久久久久久久久久久久| 欧洲一区在线电影| 亚洲国产欧美在线人成| 91日韩精品一区| 中文字幕第一区二区| 精品一区二区免费在线观看| 欧美丰满嫩嫩电影| 亚洲成va人在线观看| 色素色在线综合| 成人免费在线播放视频| 国产suv精品一区二区6| www国产精品av| 国产乱国产乱300精品| 精品99一区二区三区| 麻豆精品在线看| 欧美日韩色一区| 午夜精品久久久久久久久| 欧美片网站yy| 亚洲成av人在线观看| 91理论电影在线观看| 国产精品国产三级国产专播品爱网| 国产一区二区h| 久久精品视频网| 99vv1com这只有精品| 成人欧美一区二区三区小说| 成人91在线观看| 欧美国产丝袜视频| 国产精品自拍网站| 国产亚洲一区二区三区| 国产精品一区二区三区乱码| 欧美一区二区三区在| 国产成人aaaa| 国产精品久久一级| 成人高清伦理免费影院在线观看| 国产精品乱码一区二区三区软件| a亚洲天堂av| 亚洲自拍偷拍av| 精品国产伦一区二区三区免费| 国产福利91精品一区二区三区| 国产欧美精品一区aⅴ影院 | 欧美va亚洲va| 国产一区 二区| 国产精品久久久久影院老司| 国产毛片精品一区| 亚洲日韩欧美一区二区在线| 欧美影视一区二区三区| 肉色丝袜一区二区| 久久综合久久综合久久| 成人午夜免费视频| 亚洲综合另类小说| 欧美一区午夜视频在线观看 | 欧美日韩三级一区二区| 免费成人av资源网| 亚洲欧美二区三区| 欧美一区二区三区影视| 国产精品自在在线| 伊人开心综合网| 欧美一区二区大片| 黄页视频在线91| 亚洲一区二区三区激情| 日韩片之四级片| 不卡视频一二三| 日韩综合在线视频| 日本一区二区综合亚洲| 色狠狠综合天天综合综合| 国产伦精品一区二区三区在线观看| 日韩久久一区二区| 日韩免费观看高清完整版| kk眼镜猥琐国模调教系列一区二区| 亚洲永久精品国产| 26uuu久久天堂性欧美| 欧美日韩日日摸| 国产福利视频一区二区三区| 亚洲影院免费观看| 久久久不卡影院| 欧美日韩国产一区| 国精产品一区一区三区mba桃花| 国产精品亲子伦对白| 欧美精品第一页| 成人avav在线| 高清beeg欧美| 麻豆国产一区二区| 亚洲黄网站在线观看| 日韩精品一区二区三区在线播放 | 高清久久久久久| 久久成人久久鬼色| 亚洲一二三四区不卡| 久久久久久久久久美女| 欧美性做爰猛烈叫床潮| 丰满少妇久久久久久久| 亚洲亚洲人成综合网络| 亚洲女同女同女同女同女同69| 精品日韩在线一区| 欧美女孩性生活视频| 91在线免费播放| 国产精品一区二区久久不卡| 亚洲国产综合人成综合网站|