Microsoft MVP성태의 닷넷 이야기
내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [링크 복사], [링크+제목 복사],
조회: 10754
글쓴 사람
guest
홈페이지
첨부 파일
 

내솔루션의 exe파일을 타인이 설치 후 타인 컴퓨터 내에 Sqlite에 Write 기능이 필요한 경우

1) 타인 컴퓨터에 Write기능이 허용은 제한적이어야 하므로 타인 컴퓨터의 AppData/Local/1.0.0.0폴더만
   원칙적으로 사용할 수 있다. 이것은 Application.LocalUserAppDataPath를 의미한다.

2) 타인 컴퓨터에 프로그램설치 시 1.0.0.0 폴더가 생성되지 않는 경우도 있으므로
    Directory.CreateDirectory(destDirName)로 폴더를 생성해야 한다

위의 내용이 맞다면 만약 타인 컴퓨터에 1.0.0.0 폴더가 숨김이 적용된 상태여도
위 절차는 적용될 수 있는지요?









[최초 등록일: ]
[최종 수정일: 4/17/2023]


비밀번호

댓글 작성자
 



2023-04-17 08시29분
[guest] 질문처럼하지 않고 아래처럼 하면 자동으로 Sqlite db파일이 형성되는 지요?

public async static void InitializeDatabase()
{
     await ApplicationData.Current.LocalFolder.CreateFileAsync("sqliteSample.db", CreationCollisionOption.OpenIfExists);
     string dbpath = Path.Combine(ApplicationData.Current.LocalFolder.Path, "sqliteSample.db");
     using (SqliteConnection db =
        new SqliteConnection($"Filename={dbpath}"))
    {
        db.Open();

        String tableCommand = "CREATE TABLE IF NOT " +
            "EXISTS MyTable (Primary_Key INTEGER PRIMARY KEY, " +
            "Text_Entry NVARCHAR(2048) NULL)";

        SqliteCommand createTable = new SqliteCommand(tableCommand, db);

        createTable.ExecuteReader();
    }
}
[guest]
2023-04-17 09시45분
그냥... 직접 해보시면 것이 더 빠르지 않을까요? 원래 질문의 경우, 간단하게 폴더를 숨김 처리한 다음 그 안의 파일이 열리는지 테스트해 보시면 될 듯하고, 덧글의 질문 같은 경우에도 코드까지 만들었으니 지금 당장 해보시면 될 것 같은데요.
정성태
2023-04-18 09시58분
[guest] 여러 번 다 해봤습니다ㅜㅜ 좀 더 나은 접근법을 찾는 것이죠
고수들의 접근법이 궁금해서요

[1.0.0.0 - 이미지]
이미지가 pixabay.com처럼 수백만장이면 배포 시 1.0.0.0을 사용할 필요없지만
호스팅서비스를 비용 등의 이유로 안만드는 경우

이미지가 1만장 정도되는 경우 이 걸 user가 이용하도록 허용할 때
저렇게 하는게 스탠다드한 접근법인지요?
[guest]
2023-04-18 03시47분
[guest] [초보전용] exe파일 만들기 전에 db작업을 하는 경우
db를 repos폴더에 만들지 마시고(C:\Users\여러분\source\repos\여러분플젝이름
db는 C:\Users\여러분\AppData\Local\여러분플젝이름\여러분플젝이름\1.0.0.0\test.sqlite에
 만들면 좋을 듯 합니다 Application.LocalUserAppDataPath가 1.0.0.0주소네요

[db만들기/table생성 코드]
MessageBox.Show(Application.LocalUserAppDataPath);
string path1 = Path.Combine(Application.LocalUserAppDataPath, "synccc.sqlite");
string dbConnectionString = @"Data Source=" + path1 + ";Version=3;";

if (!System.IO.File.Exists(path1))
{
    SQLiteConnection.CreateFile(path1);

    using (SQLiteConnection sqliteConnection = new SQLiteConnection(path1))
    {
        sqliteConnection.Open();

        using (SQLiteCommand sqliteCommand = new SQLiteCommand(sqliteConnection))
        {
             sqliteCommand.CommandText = @"CREATE TABLE Cars(Id INTEGER PRIMARY KEY, Name TEXT, Price INT)";

              sqliteCommand.ExecuteNonQuery();
        }

        sqliteConnection.Close();
    }
}
[guest]
2023-04-21 08시22분
[gwise] exe파일이 설치됐다면 그 폴더에는 read/write 권한이 있다는 얘기겠죠. 그럼 그 폴더에 sqlite을 생성하면 됩니다.

생성은 크게 초기에 하는 것과 컬럼 수정으로 나눠서 보면 됩니다.
1. 생성
생성은 매번 호출 될 터이니 아래 처럼 if not exists 를 해주시고
string sql = string.Empty;
//Item
sql = @"CREATE TABLE if not exists Item(
        [ItemId] INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
        [ItemName] TEXT NOT NULL,
        [Barcode] TEXT NOT NULL DEFAULT(''),
        [Sku] TEXT NOT NULL DEFAULT(''),
        [Location] TEXT NOT NULL DEFAULT(''),
        [Category] TEXT NOT NULL DEFAULT(''),
        [UnitCost] NUMERIC NOT NULL DEFAULT(0),
        [UnitPrice] NUMERIC NOT NULL DEFAULT(0),
        [IsUsed] TEXT NOT NULL DEFAULT('Y'),
        [Comment] TEXT NOT NULL DEFAULT(''),
        [CreatedDate] TEXT NOT NULL DEFAULT(strftime('%Y-%m-%d %H:%M:%f', 'now', 'localtime')),
        [CreatedEmp] TEXT NOT NULL DEFAULT(''),
        [ModifiedDate] TEXT NOT NULL DEFAULT(strftime('%Y-%m-%d %H:%M:%f', 'now', 'localtime')),
        [ModifiedEmp] TEXT NOT NULL DEFAULT(''),
        [AddColumns] TEXT NOT NULL DEFAULT('')
    )";
new SqliteCommand(sql, conn).ExecuteNonQuery();

sql = @"CREATE Unique INDEX if not exists [Item.idx1] ON Item ([ItemName])";
new SqliteCommand(sql, conn).ExecuteNonQuery();

2. 컬럼 추가
컬럼이 추가 됐는지 확인 하고
public bool AddColumnIfExist(string table, string column)
{
    using (SqliteConnection connection = CreateConnection())
    {
        SqliteCommand selectCommand = new SqliteCommand();
        selectCommand.Connection = connection;
        selectCommand.CommandText = $"PRAGMA table_info({table});";
        SqliteDataReader reader = selectCommand.ExecuteReader();

        while (reader.Read())
        {
            if (column.Equals(reader["name"]))
            {
                Console.WriteLine("OK");
                return true;
            }
        }
    }
    return false;
}

없다면 컬럼 추가
public int AlterTableAddColumn(string table, string column, string type)
{
    int result;
    using (SqliteConnection connection = CreateConnection())
    {
        SqliteCommand selectCommand = new SqliteCommand();
        selectCommand.Connection = connection;
        selectCommand.CommandText = $"ALTER TABLE {table} ADD {column} {type};";
        result = selectCommand.ExecuteNonQuery();
    }

    return result;
}

이렇게 하면 됩니다.
[guest]

... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
321셈토2/18/200610860SPOOL --> EMF --> TEXTOUT [1]
320정보문2/18/200610671파일의 최대 크기2 [1]
318정보문2/18/200611815파일의 최대 크기
319정성태2/18/200611834    답변글 [답변]: 파일의 최대 크기 [1]
317narc...2/17/200610977[IE embeded SmartClient]에서 닷넷 리모팅 프록시 사용시 처음 2분간 딜레이현상이 발생합니다. [1]
322narc...2/20/200611805    답변글 [답변]: 다시한번 부탁드리겠습니다..
316이경찬2/15/200613209MSDN 매거진 정기구독 신청은 어디서 할수있나요? [1]
315정준명2/15/200616641[DxFramework Lite] 분산 트랜잭션에 참여하는 동안 오류가 발생했습니다. [2]
314이윤희2/14/200610858엑셀변환시....그림을 넣을려면. [1]
313장강현2/14/200611011SmartClient 디버그 문제 [1]
312정보문2/13/200611066방법2006 [1]
309정보문2/10/200612230edit & continue [3]
308김용국2/11/200610696스마트클라이언트 관련질문 [ Client 에서 WebPage의 JavaScript 호출방법이 있을까요? 있다고는 한것 같은데..부탁드림^^
310정성태2/11/200610217    답변글 [답변]: 스마트클라이언트 관련질문 [ Client 에서 WebPage의 JavaScript 호출방법이 있을까요? 있다고는 한것 같은데..부탁드림^^
307narc...2/10/200611943IE Embeded 스마트클라이언트는 UserControl만 가능한가요? [2]
305정보문2/10/200612060웹 컨트롤
306정성태2/10/200611696    답변글 [답변]: 웹 컨트롤
303정보문2/10/200612635회원가입성공을 기념으로 질문 한 가지 던집니다.
304정성태2/10/200611036    답변글 [답변]: 회원가입성공을 기념으로 질문 한 가지 던집니다.
302김성2/7/200612181C#이나 VB.NET 으로 만든 것을 SETUP 해서 배포하려고 하는데요.. [1]
301참깨2/3/200616429개체가 이 속성 또는 메소드를 지원하지 않습니다. [1]
300김종욱2/2/200610836안녕하세요 [2]
299꼬부기1/19/200610063스마트클라이언트 관련 질문입니다... [2]
298정말초짜1/12/200610289smart client 질문입니다. [1]
296우승우1/4/20069959스마트클라이언트에서 COM+를 이용한 데이터 가져 오기..
297정성태1/4/200611917    답변글 [답변]: 스마트클라이언트에서 COM+를 이용한 데이터 가져 오기.. [2]
... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...