⑴ 請問CVS是什麼啊
CVS是「Concurrent Version System」的簡稱,即是是一個C/S系統,常用的代碼版本控制軟體。
CVS是開發源代碼的配置管理工具,其源代碼和安裝文件都可以免費下載。CVS是源於unix的版本控制工具,對於CVS的安裝和使用最好對unix的系統有所了解能更容易學習。
CVS的伺服器管理需要進行各種命令行操作。目前,CVS的客戶端有winCVS的圖形化界面,伺服器端也有CVSNT的版本,易用性正在提高。但因為CVS是開發源碼軟體,沒有生產廠家為其提供技術的支持。如發現問題,通常只能靠自己查找網上的資料進行解決。
(1)cvsjava擴展閱讀:
cvs替代管理
cvs 不能代替開發者之間的交流。在單個文件內遇到沖突時,大多數開發者不費多大力氣就能解決它們。但更常見的"沖突(conflict)",是那些難度較大、不在開發者之間進行交流就沒法解決的問題。
當在一個文件內或多個文件中同時發生變化時,cvs 並不知道何時它們會在邏輯上發生沖突。它的沖突(conflict)概念是純粹文本意義上的,這種沖突會在同一個文件的兩種變化十分接近以致於會破壞合並命令(如diff3)。
cvs 決不會指出程序邏輯上非文本或分布式的沖突。例如:假如你改變了在文件A 中定義的函數X 的參數。同時,別人在編輯文件B,仍用舊參數調用 X 這個函數。此時產生的沖突 cvs 可就無能為力了。
⑵ java中怎樣生成cvs文件
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import org.apache.commons.beanutils.BeanUtils;
public class CSVUtils {
public static File createCSVFile(List exportData, LinkedHashMap rowMapper,
String outPutPath, String filename) {
File csvFile = null;
BufferedWriter csvFileOutputStream = null;
try {
csvFile = new File(outPutPath + filename + ".csv");
// csvFile.getParentFile().mkdir();
File parent = csvFile.getParentFile();
if (parent != null && !parent.exists()) {
parent.mkdirs();
}
csvFile.createNewFile();
// GB2312使正蔽頌確讀取分隔符","
csvFileOutputStream = new BufferedWriter(new OutputStreamWriter(
new FileOutputStream(csvFile), "GB2312"), 1024);
// 寫入文件頭部
for (Iterator propertyIterator = rowMapper.entrySet().iterator(); propertyIterator
.hasNext();) {
java.util.Map.Entry propertyEntry = (java.util.Map.Entry) propertyIterator
.next();
csvFileOutputStream.write("顫御\""
+ propertyEntry.getValue().toString() + "\"");
if (propertyIterator.hasNext()) {
csvFileOutputStream.write(",");
}
}
csvFileOutputStream.newLine();
// 寫入文件內宏洞鄭容
for (Iterator iterator = exportData.iterator(); iterator.hasNext();) {
Object row = (Object) iterator.next();
System.out.println(row);
for (Iterator propertyIterator = rowMapper.entrySet().iterator(); propertyIterator.hasNext();) {
java.util.Map.Entry propertyEntry = (java.util.Map.Entry) propertyIterator.next();
System.out.println( BeanUtils.getProperty(row, propertyEntry.getKey().toString()));
csvFileOutputStream.write("\""
+ propertyEntry.getValue().toString() + "\"");
if (propertyIterator.hasNext()) {
csvFileOutputStream.write(",");
}
}
if (iterator.hasNext()) {
csvFileOutputStream.newLine();
}
}
csvFileOutputStream.flush();
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
csvFileOutputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return csvFile;
}
public static void main(String[] args) {
List exportData = new ArrayList<Map>();
Map row1 = new LinkedHashMap<String, String>();
row1.put("1", "11");
row1.put("2", "12");
row1.put("3", "13");
row1.put("4", "14");
exportData.add(row1);
row1 = new LinkedHashMap<String, String>();
row1.put("1", "21");
row1.put("2", "22");
row1.put("3", "23");
row1.put("4", "24");
exportData.add(row1);
List propertyNames = new ArrayList();
LinkedHashMap map = new LinkedHashMap();
map.put("1", "第一列");
map.put("2", "第二列");
map.put("3", "第三列");
map.put("4", "第四列");
CSVUtils.createCSVFile(exportData, map, "d:/aaaaaa/mmm/", "活動目錄");
}
}
補充;Java是一種可以撰寫跨平台應用程序的面向對象的程序設計語言。Java 技術具有卓越的通用性、高效性、平台移植性和安全性,廣泛應用於PC、數據中心、游戲控制台、科學超級計算機、行動電話和互聯網,同時擁有全球最大的開發者專業社群。
⑶ java 從資料庫中查出10萬級條數據 生成cvs格式文件
10萬條也不算很大吧,查出來寫成csv不就完了嗎?csv實際上就是一個文改帶本文件核纖蘆,每行是一豎旁條數據,每條數據各個欄位之間以逗號分隔,就行了
⑷ 求助,java導出cvs中文亂碼,包含特殊字元,使用的編碼格式為utf-8
沒弄過。不洞神知道這樣子可以不可以。
將cvs當做txt看待。唔打開吵汪的時候都升顫仔是用的記事本。
FileOutputStream out1 = new FileOutputStream("C:\\test.cvs");
OutputStreamWriter out2 = new OutputStreamWriter(out1,"UTF-8");
⑸ Java項目被覆蓋,怎樣從CVS重新檢出詳細步驟怎樣操作急!
窗口->打開透視圖->cvs存儲庫研究->氏液
點你蘆辯的存儲位置->展開head->選擇項目checkout
我的是中文的eclipse哈殲嘩物,哈哈哈。
⑹ java中怎麼從.CVS文件讀寫數據
CSV文件是以逗號分割的數據倉儲,讀取數據時從每一行中讀取一條數據元祖,也就鄭橡局是一條數據,再如枝用字元分割的方式喊讓獲取表中的每一個數據項。
⑺ java從CVS中導出的工程報告如下幾個錯誤
第一個:可能是class文件滑慧沒刪除還是怎麼吧
第二個錯誤解決辦法:
1.
進入window
\
preferences
\
java
\
Installed
JREs
1)按Add
2)輸入JRE
Name,
例JDK1.5.0.09
3)JRE
home
directory,
選擇安裝燃燃的路徑皮讓虛
4)按OK
2.
進入Project
\
properties
\
Java
Bulid
Path
1)Add
library
2)選JRE
System
Library後按Next
3)選workplace
default
JRE後按
finish...
建議你多看看資料,我們拿我們公司的項目從沒出過錯,可能是你哪裡沒注意到。
⑻ Java程序員們請進,請問CVS里的checkout是什麼意思請詳細點。。
初始化:CVS版本庫的初始化。 cvs init
一個項目的首次導入 cvs import -m "write some comments here" project_name vendor_tag release_tag 執行後:會將所有源文件及目錄導入到/path/to/cvsroot/project_name目錄下 vender_tag: 開發商標記 release_tag: 版本發布標記
項目導出:將代碼從CVS庫里導出 cvs checkout project_name cvs 將創建project_name目錄,並將最新版本的源代碼導出到相應目錄中。這個checkout和Virvual SourceSafe中的check out不是一個概念,相對於Virvual SourceSafe的check out是cvs update, check in是cvs commit。
CVS的日常使用
注意:第一次導出以後,就不是通過cvs checkout來同步文件了,而是要進入剛才cvs checkout project_name導出的project_name目錄下進行具體文件的版本同步(添加,修改,刪除)操作。
將文件同步到最新的版本 cvs update 不制定文件名,cvs將同步所有子目錄下的文件,也可以制定某個文件名/目錄進行同步 cvs update file_name 最好每天開始工作前或將自己的工作導入到CVS庫里前都要做一次,並養成「先同步 後修改」的習慣,和Virvual SourceSafe不同,CVS里沒有文件鎖定的概念,所有的沖突是在commit之前解決,如果你修改過程中,有其他人修改並commit到了CVS 庫中,CVS會通知你文件沖突,並自動將沖突部分用 >>>>>> content on cvs server <<<<<< content in your file >>>>>> 標記出來,由你確認沖突內容的取捨。版本沖突一般是在多個人修改一個文件造成的,但這種項目管理上的問題不應該指望由CVS來解決。
確認修改寫入到CVS庫里 cvs commit -m "write some comments here" file_name
注意:CVS的很多動作都是通過cvs commit進行最後確認並修改的,最好每次只修改一個文件。在確認的前,還需要用戶填寫修改注釋,以幫助其他開發人員了解修改的原因。如果不用寫-m "comments"而直接確認`cvs commit file_name` 的話,cvs會自動調用系統預設的文字編輯器(一般是vi)要求你寫入注釋。注釋的質量很重要:所以不僅必須要寫,而且必須寫一些比較有意義的內容:以方便其他開發人員能夠很好的理解不好的注釋,很難讓其他的開發人員快速的理解:比如: -m "bug fixed" 甚至 -m "" 好的注釋,甚至可以用中文: -m "在用戶注冊過程中加入了Email地址校驗"
修改某個版本注釋:每次只確認一個文件到CVS庫里是一個很好的習慣,但難免有時候忘了指定文件名,把多個文件以同樣注釋commit到CVS庫里了,以下命令可以允許你修改某個文件某個版本的注釋: cvs admin -m 1.3:"write some comments here" file_name
添加文件創建好新文件後,比如:touch new_file cvs add new_file 注意:對於圖片,Word文檔等非純文本的項目,需要使用cvs add -kb選項按2進制文件方式導入(k表示擴展選項,b表示binary),否則有可能出現文件被破壞的情況比如: cvs add -kb new_file.gif cvs add -kb readme.doc
如果關鍵詞替換屬性在首次導入時設置錯了怎麼辦? cvs admin -kkv new_file.css
然後確認修改並注釋 cvs ci -m "write some comments here"
刪除文件將某個源文件物理刪除後,比如:rm file_name cvs rm file_name 然後確認修改並注釋 cvs ci -m "write some comments here" 以上面前2步合並的方法為: cvs rm -f file_name cvs ci -m "why delete file" 注意:很多cvs命令都有縮寫形式:commit=>ci; update=>up; checkout=>co/get; remove=>rm;
添加目錄 cvs add dir_name
查看修改歷史 cvs log file_name cvs history file_name
查看當前文件不同版本的區別 cvs diff -r1.3 -r1.5 file_name 查看當前文件(可能已經修改了)和庫中相應文件的區別 cvs diff file_name cvs的web界面提供了更方便的定位文件修改和比較版本區別的方法,具體安裝設置請看後面的cvsweb使用
正確的通過CVS恢復舊版本的方法:如果用cvs update -r1.2 file.name 這個命令是給file.name加一個STICK TAG: "1.2" ,雖然你的本意只是想將它恢復到1.2版本正確的恢復版本的方法是:cvs update -p -r1.2 file_name >file_name 如果不小心已經加成STICK TAG的話:用cvs update -A 解決
移動文件/文件重命名 cvs里沒有cvs move或cvs rename,因為這兩個操作是可以由先cvs remove old_file_name,然後cvs add new_file_name實現的。
刪除/移動目錄最方便的方法是讓管理員直接移動,刪除CVSROOT里相應目錄(因為CVS一個項目下的子目錄都是獨立的,移動到$CVSROOT目錄下都可以作為新的獨立項目:好比一顆樹,其實砍下任意一枝都能獨立存活),對目錄進行了修改後,要求其開發人員重新導出項目cvs checkout project_name 或者用cvs update -dP同步。
項目發布導出不帶CVS目錄的源文件做開發的時候你可能注意到了,每個開發目錄下,CVS都創建了一個CVS/目錄。裡面有文件用於記錄當前目錄和CVS庫之間的對應信息。但項目發布的時候你一般不希望把文件目錄還帶著含有CVS信息的CVS目錄吧,這個一次性的導出過程使用cvs export命令,不過export只能針對一個TAG或者日期導出,比如: cvs export -r release1 project_name cvs export -D 20021023 project_name cvs export -D now project_name
⑼ 用java編寫,將cvs導入mysql
package me.test;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.List;
import org.skife.csv.CSVReader;
import org.skife.csv.SimpleReader;
/**
* 說明:作為示例,將CSV中的數據插入到資料庫中。
* 注意:僅僅是功能性示例,沒有try...catch...,請自行追加,並確認該如何commit和rollback。
*
*
* 資料庫DDL:
* CREATE TABLE USER (ID INT , NAME VARCHAR(45), PRIMARY KEY(ID));
*
* CSV文件(C:/t.csv)中的數據內容
* 1, 張三
* 2, 李四
* 3, 王五
*
* 參考笑模第三方類庫:
* MySQL Jdbc驅動包
* http://www.mysql.com/procts/connector/
* Apache commons CSV -> Skife CSV -> csv-1.0.jar
* http://commons.apache.org/sandbox/csv/
*
* @author [email protected]
*/
public class Csv2DB {
//氏升派 測試代碼
@SuppressWarnings("unchecked")
public static void main(String args[]) throws ClassNotFoundException,
SQLException, IOException {
// 載入驅動類
Class.forName("org.gjt.mm.mysql.Driver");
// 創建資料庫連接殲賀
String url = "jdbc:mysql://localhost:3306/test";
String userName = "root";
String password = "123456";
Connection conn = DriverManager.getConnection(url, userName, password);
String sql = "INSERT INTO USER(ID, NAME) VALUES(?,?)";
PreparedStatement stmt = conn.prepareStatement(sql);
conn.setAutoCommit(false);
CSVReader reader = new SimpleReader();
// CSV 文件路徑
String csvFilePath = "C:/t.csv";
// CSV 文件中是否有一條頭部記錄(非數據,類似於列名)
boolean hasHeaderRec = false;
List<String[]> recList = reader.parse(new File(csvFilePath));
for (int i = 0; i < recList.size(); i++) {
String[] rec = recList.get(i);
if (i == 0 && hasHeaderRec) {
continue; // 跳過頭部記錄
}
stmt.clearParameters();
stmt.setInt(1, Integer.valueOf(rec[0]));
stmt.setString(2, rec[1]);
stmt.execute();
}
stmt.close();
conn.commit();
conn.close();
System.out.println("success");
}
}
⑽ 請教JAVA中CVS的問題
你先在本地刪除那個文件夾,然後去cvs commit下伺服器和本地就都沒有了