Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,027

HOME > .NET Framework > Forum > SQL INSTANCENAME DISCOVERY หา instance ของ sqlserver ของเครื่องคอมพิวเตอร์ แก้ปัญหา connect ไม่เจอ ย้ายเครื่อง ฯ



 

SQL INSTANCENAME DISCOVERY หา instance ของ sqlserver ของเครื่องคอมพิวเตอร์ แก้ปัญหา connect ไม่เจอ ย้ายเครื่อง ฯ

 



Topic : 114420



โพสกระทู้ ( 21 )
บทความ ( 0 )



สถานะออฟไลน์




เห็นหลาย post มีปัญหากันกับการ connect sqlserver กัน
ก็มีที่เขียนๆไว้เพื่ออำนวยความสะดวกอยู่บ้าง
เลยขออนญาตเอามาแปะบ้างอะไรบ้างเผื่อจะมีใครต้องการใช้

หมายเหตุ
ยังไม่ได้ลองกับเครื่องที่ลง sql server หลายๆ version เช่น 2005 คู่กับ 2012
และหากมีข้อผิดพลาดกรุณาโพสที่นี่เพื่อจะได้แก้ไขให้ต่อไปครัช
ให้ add reference > System.Management ด้วย


Info:
Net framework : 4.5
Language : VB.NET

พ่วงมาใน sqlHelper ที่เป็น module ช่วยอำนวยความสะดวกในการติดต่อกับ ADO.NET

ในส่วนการติดต่อกับ ADO.NET นั้น
ใช้วิธีเขียนแบบ sql execute ของ linq ในการนำ parameter เข้ามา
เช่น INSERT INTO [TABLE] VALUES (@NAME ,@GENDER ,@DESCRIPTION)
ซึ่งมีตัวแปร myName ,myGender ,myDescription เก็บค่าเอาไว้
ใน SQLHELPER จะใช้ Pattern นี้
RunQuery("INSERT INTO [TABLE] VALUES ({0} ,{1} ,{2})" ,myName ,myGender ,myDescription)
และ support Command ธรรมดาที่ไม่มี parameter ได้เช่นกัน
>>RunQuery("DELETE FROM [TEMPDATA]")
และการเริ่มใช้งานนั้นจะต้องกำหนด ConnectionString ให้ก่อนครั้งแรกครั้งเดียว
ซึ่งจะอ่านมาจาก Web.config หรือกำหนด connection string โดยตรงเลยก็ได้
โดยการอ่านค่าจาก web.config ใช้ method : GetConnectionStringFromWebConfig

เช่นใน webConfig เก็บ connectionstring ไว้ในชื่อ DefaultConnectionString
ให้เรียก GetConnectionStringFromWebConfig("DefaultConnectionString") เป็นต้น

Code (XML)
<?xml version="1.0"?>
<!--
  For more information on how to configure your ASP.NET application, please visit
  http://go.microsoft.com/fwlink/?LinkId=169433
  -->
<configuration>
  <connectionStrings>
    <add name="DefaultConnectionString " connectionString="Data Source=DEV02\SQLEXPRESS2012;Initial Catalog=MYDATA;Integrated Security=True"
      providerName="System.Data.SqlClient" />
  </connectionStrings>
  <system.web>   


ในส่วน SQL SERVER INSTANCE DISCOVERY
และใช้ Function EnumerateSQLInstances ทำหน้าที่นี้
โดยที่หาก return ค่าเป็น true จะหมายความว่าพบ sql instance ในเครื่องนี้
และจัดเก็บ info ต่างๆใน object SqlServerInstanceAlias
ชื่อ instance จะอยู่ที่ > SqlServerInstanceAlias.InstanceName

Code (VB.NET)
Imports System.Configuration
Imports System.Data
Imports System.Data.SqlClient
Imports System
Imports Microsoft.VisualBasic
Imports System.Management

Namespace DatabaseUtility
    ''' <summary>
    ''' SqlHelper >> Simple and clean module for associated ms sql server.
    ''' Inspired from Entityframework executecommand method. 
    ''' Write by S. Chursittisak
    ''' Rev 1.02 Date 2015/01/10
    ''' </summary>
    ''' <remarks></remarks>
    Public Module SqlHelper

        Public ConnectionString As String = String.Empty
        Public hasGenerateError As Boolean = False


        ''' <summary>
        ''' Run this method first such as global.asax or whatever before uses this module 
        ''' </summary>
        ''' <param name="ConnectionStringName"></param>
        ''' <returns></returns>
        ''' <remarks></remarks>
        Public Function ReadConnectionStringFromWebConfig(ByVal ConnectionStringName As String) As String
            Dim rootWebConfig As System.Configuration.Configuration
            rootWebConfig = System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration("/MyWebSiteRoot")
            Dim connString As System.Configuration.ConnectionStringSettings
            If (rootWebConfig.ConnectionStrings.ConnectionStrings.Count > 0) Then
                connString = rootWebConfig.ConnectionStrings.ConnectionStrings(ConnectionStringName)
                If Not (connString.ConnectionString = Nothing) Then
                    Return connString.ConnectionString
                End If
            End If

            Return String.Empty
        End Function


        Public Sub GetConnectionStringFromWebConfig(ByVal ConnectionStringName As String)
            Dim rootWebConfig As System.Configuration.Configuration
            rootWebConfig = System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration("/MyWebSiteRoot")
            Dim connString As System.Configuration.ConnectionStringSettings
            If (rootWebConfig.ConnectionStrings.ConnectionStrings.Count > 0) Then
                connString = rootWebConfig.ConnectionStrings.ConnectionStrings(ConnectionStringName)
                If Not (connString.ConnectionString = Nothing) Then
                    SqlHelper.ConnectionString = connString.ConnectionString
                    Return
                End If
            End If
            SqlHelper.ConnectionString = String.Empty
        End Sub

        Private Function SqlCommandComposer _
            (ByVal command As SqlCommand, ByVal ParamArray Param() As Object) As SqlCommand
            Dim ParamName As String = String.Empty

            Dim CommandText As String = command.CommandText

            If (Param.Length > 0) Then
                For i As Integer = 0 To Param.Length - 1
                    ParamName = "arg" & i.ToString()
                    command.Parameters.AddWithValue(ParamName, Param(i))
                    CommandText = CommandText.Replace("{" & i.ToString() & "}", "@" & ParamName)
                Next
                command.CommandText = CommandText
            End If

            Return command

        End Function

        Public Function RunQuery(ByVal CommandText As String, ByVal ParamArray Param() As Object) As Integer

            Dim Result As Integer = 0

            Using mConnection As New SqlConnection(SqlHelper.ConnectionString)
                Dim mCommand As New SqlCommand(CommandText, mConnection)
                Try
                    mCommand = SqlHelper.SqlCommandComposer(mCommand, Param)
                    mConnection.Open()
                    Result = mCommand.ExecuteNonQuery()
                Catch ex As Exception
                    If hasGenerateError Then
                        Throw ex
                    End If
                    Result = -1
                End Try
            End Using
            Return Result
        End Function

        Public Function RunQueryEx(ByVal CommandText As String, ByVal ParamArray Param() As Object) As Object

            Dim retVal As Object = Nothing

            Using mConnection As New SqlConnection(SqlHelper.ConnectionString)
                Dim mCommand As New SqlCommand(CommandText, mConnection)
                Try
                    mCommand = SqlHelper.SqlCommandComposer(mCommand, Param)
                    mConnection.Open()
                    retVal = mCommand.ExecuteScalar()
                Catch ex As Exception
                    If hasGenerateError Then
                        Throw ex
                    End If
                End Try
            End Using
            Return retVal
        End Function

        Public Function GetDataSetFromQuery(ByVal CommandText As String, ByVal ParamArray Param() As Object) As DataSet
            Dim ResultDataSet As New DataSet

            Using mConnection As New SqlConnection(SqlHelper.ConnectionString)
                Dim mCommand As New SqlCommand(CommandText, mConnection)
                mCommand = SqlHelper.SqlCommandComposer(mCommand, Param)
                Dim mDataAdapter As New SqlDataAdapter(mCommand)
                Try
                    mDataAdapter.Fill(ResultDataSet)
                Catch ex As Exception
                    If hasGenerateError Then
                        Throw ex
                    End If
                End Try
            End Using
            Return ResultDataSet
        End Function

        Public Function GetDataTableFromQuery(ByVal CommandText As String, ByVal ParamArray Param() As Object) As DataTable
            Dim ResultDataTable As New DataTable

            Using mConnection As New SqlConnection(SqlHelper.ConnectionString)
                Dim mCommand As New SqlCommand(CommandText, mConnection)
                mCommand = SqlHelper.SqlCommandComposer(mCommand, Param)
                Dim mDataAdapter As New SqlDataAdapter(mCommand)
                Try
                    mDataAdapter.Fill(ResultDataTable)
                Catch ex As Exception
                    If hasGenerateError Then
                        Throw ex
                    End If
                End Try
            End Using
            Return ResultDataTable
        End Function


        Public Function TestConnection(ByRef ErrorMessage As String) As Boolean
            Dim bRet As Boolean = False
            Using mConnection As New SqlConnection(SqlHelper.ConnectionString)
                Try
                    mConnection.Open()
                    bRet = False
                    ErrorMessage = String.Empty
                Catch ex As Exception
                    ErrorMessage = ex.Message
                End Try
            End Using
            Return bRet
        End Function
#Region "SQL SERVER INSTANCE DISCOVERY"
        'origin source from http://social.technet.microsoft.com/wiki/contents/articles/940.how-to-embed-sql-server-express-in-an-application.aspx?PageIndex=2

        ''' <summary>
        ''' Main function for get all posible sqlserver instance on computer.
        ''' Usage 
        '''       Dim instanceList As List(Of SqlServerInstanceAlias) = New List(Of SqlServerInstanceAlias)
        '''       EnumerateSQLInstances(instanceList)
        ''' </summary>
        ''' <param name="instanceList"></param>
        ''' <returns></returns>
        ''' <remarks></remarks>
        Public Function EnumerateSQLInstances(ByVal instanceList As List(Of SqlServerInstanceAlias)) As Boolean

            Dim correctNamespace As String = GetCorrectWmiNamespace()

            If String.Equals(correctNamespace, String.Empty) Then
                Return False
            End If

            If (instanceList Is Nothing) Then
                instanceList = New List(Of SqlServerInstanceAlias)
            End If


            Dim query As String = String.Format("select * from SqlServiceAdvancedProperty " &
                                                " where SQLServiceType = 1 and PropertyName = 'instanceID'")
            Dim getSqlEngine As New System.Management.ManagementObjectSearcher _
                With {.Scope = New ManagementScope(correctNamespace), .Query = New ObjectQuery(query)}

            If getSqlEngine.Get().Count = 0 Then
                Return False
            End If
            'Console.WriteLine("SQL Server database instances disovered :")

            Dim instanceName As String = String.Empty
            Dim serviceName As String = String.Empty
            Dim version As String = String.Empty
            Dim edition As String = String.Empty

            'Console.WriteLine("Instance name {0} ServiceName {0} Edition {0} Version {0}", vbTab)


            For Each sqlEngine As ManagementObject In getSqlEngine.Get()
                serviceName = sqlEngine("ServiceName").ToString()
                instanceName = GetInstanceNameFromServiceName(serviceName)
                version = GetWmiPropertyValueForEngineService(serviceName, correctNamespace, "Version")
                edition = GetWmiPropertyValueForEngineService(serviceName, correctNamespace, "SKUNAME")
                instanceList.Add(New DatabaseUtility.SqlServerInstanceAlias(serviceName, instanceName, version, edition))
            Next

            Return True


        End Function

        ''' <summary>
        ''' Method returns the correct SQL namespace to use to detect SQL Server instances.
        ''' </summary>
        ''' <returns>namespace to use to detect SQL Server instances</returns>
        Function GetCorrectWmiNamespace() As String
            Dim wmiNamspaceToUse As String = "root\Microsoft\SqlServer"
            Dim compareKey As String = "ComputerManagement"
            Dim namespaces As New List(Of String)
            Try
                'Enumerate all WMI instances of
                '__namespace WMI class.
                Dim nsClass As New ManagementClass With _
                    {.Scope = New ManagementScope(wmiNamspaceToUse), .Path = New ManagementPath("__namespace")}

                For Each ns As ManagementObject In nsClass.GetInstances()
                    namespaces.Add(ns("Name").ToString())
                Next
            Catch ex As ManagementException
                Throw New Exception(ex.Message)
                'Console.WriteLine("Exception = %1", ex.Message)
            End Try
            If namespaces.Count > 0 Then

                For i As Integer = 0 To namespaces.Count - 1

                    If (namespaces(i).IndexOf(compareKey) >= 0) Then
                        wmiNamspaceToUse = wmiNamspaceToUse + "\" + namespaces(i)
                        Exit For
                    End If
                Next
            Else
                wmiNamspaceToUse = String.Empty
            End If
            Return wmiNamspaceToUse


        End Function
        ''' <summary>
        ''' method extracts the instance name from the service name
        ''' </summary>
        ''' <param name="serviceName"></param>
        ''' <returns></returns>
        Function GetInstanceNameFromServiceName(ByVal serviceName As String) As String
            If Not String.IsNullOrEmpty(serviceName) Then
                If String.Equals(serviceName, "MSSQLSERVER", StringComparison.OrdinalIgnoreCase) Then
                    Return serviceName
                Else
                    Return serviceName.Substring(serviceName.IndexOf("$"c) + 1, serviceName.Length - serviceName.IndexOf("$"c) - 1)
                End If
            Else
                Return String.Empty
            End If
        End Function

        ''' <summary>
        ''' Returns the WMI property value for a given property name for a particular SQL Server service Name
        ''' </summary>
        ''' <param name="serviceName">The service name for the SQL Server engine service to query for</param>
        ''' <param name="wmiNamespace">The wmi namespace to connect to </param>
        ''' <param name="propertyName">The property name whose value is required</param>
        ''' <returns></returns>

        Function GetWmiPropertyValueForEngineService(ByVal serviceName As String, ByVal wmiNamespace As String, ByVal propertyName As String) As String
            Dim propertyValue As String = String.Empty
            Dim query As String = String.Format("select * from SqlServiceAdvancedProperty " &
                                                " where SQLServiceType = 1 and PropertyName = '{0}' and ServiceName = '{1}'" _
                                                , propertyName, serviceName)
            Dim propertySearcher As New ManagementObjectSearcher _
                With {.Scope = New ManagementScope(wmiNamespace), .Query = New ObjectQuery(query)}
            For Each sqlEdition As ManagementObject In propertySearcher.Get()
                propertyValue = sqlEdition("PropertyStrValue").ToString()
            Next
            Return propertyValue
        End Function

#End Region
    End Module

    Public Class SqlServerInstanceAlias
        Public Property ServiceName As String = String.Empty
        Public Property InstanceName As String = String.Empty
        Public Property Version As String = String.Empty
        Public Property Edition As String = String.Empty

        Public Sub New()
        End Sub
        Public Sub New(ByVal ServiceName As String, ByVal InstanceName As String, ByVal Version As String, ByVal Edition As String)
            Me.ServiceName = ServiceName
            Me.InstanceName = InstanceName
            Me.Version = Version
            Me.Edition = Edition
        End Sub
        Public Overrides Function ToString() As String
            Return String.Format("Servicename=({0});Instancename=({1});Version=({2});Edition=({3})", Me.ServiceName, Me.InstanceName, Me.Version, Me.Edition)
        End Function
        ''' <summary>
        ''' Yield string with limiter such as <br /> in asp.net or vbcrlf in console apps.
        ''' </summary>
        ''' <param name="Saparator"></param>
        ''' <returns></returns>
        ''' <remarks></remarks>
        Public Overloads Function ToString(ByVal Saparator As String) As String
            Return String.Format("Servicename=({0});{4}Instancename=({1});{4}Version=({2});{4}Edition=({3})" _
                                 , Me.ServiceName, Me.InstanceName, Me.Version, Me.Edition, Saparator)
        End Function

    End Class
End Namespace






Tag : .NET, VB.NET, VS 2012 (.NET 4.x)









ประวัติการแก้ไข
2015-02-14 12:23:36
2015-02-14 12:31:30
2015-02-14 12:45:09
2015-02-14 20:22:49
Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-02-14 12:21:42 By : BIG BAD DOG View : 1241 Reply : 3
 

 

No. 1

Guest


@DOG{B} สไตล์การเขียนโปรแกรมของคุณไกล้เคียงกับของผมมาก (ดูผ่านฯยากที่จะเห็นข้อแตกต่าง)

อันนี้ใช้ได้กับทุกฯ RDBMS (ที่สนับสนุน .NET Connector)

Code (VB.NET)
    Public Shared Function Query(ByVal strSQL As String, ByVal lstParam As List(Of DbParameter)) As DataTable
        Dim dtReturn As New DataTable()
        Using Conn As DbConnection = DbProviderVB.CreateConnection()
            Using da As DbDataAdapter = DbProviderVB.GetFactory().CreateDataAdapter()
                Using cmd As DbCommand = Conn.CreateCommand()
                    cmd.CommandText = DbProviderVB.FixedParam(strSQL) '*****
                    cmd.Parameters.Clear()
                    If lstParam.Count > 0 Then
                        cmd.Parameters.AddRange(lstParam.ToArray())
                    End If
                    da.SelectCommand = cmd
                    Conn.Open() 'FOR --> Visual FoxPro, Dbase, MSAccess
                    da.Fill(dtReturn)
                End Using
            End Using
        End Using
        Return dtReturn
    End Function

    Public Shared Function FixedParam(ByVal strSQL As String, Optional ByVal pvdStr As String = "") As String
        If pvdStr = String.Empty Then
            pvdStr = providerName 'Read from web.config
        End If
        'Change (@\w*) TO (@\w+) 2012-08-20
        '* = Zero or more
        '+ = One or more
        '? = Zero or one
        '"(@\w+^')"
        '^ Match the beginning of the input string.
        Select Case pvdStr
            Case "System.Data.SqlClient", "System.Data.MySqlClient", "System.Data.DB2Client", "FirebirdSql.Data.FirebirdClient", "System.Data.SQLite"
                Return strSQL
            Case "Oracle.ManagedDataAccess.Client" ', "System.Data.OracleClient"
                strSQL = Regex.Replace(strSQL, "(@\w+)", Function(m) ":" & m.Value.Replace(" ", "").Substring(1))
            Case "System.Data.OleDb", "System.Data.Odbc", "System.Data.VFPClient"
                strSQL = Regex.Replace(strSQL, "(@\w+)", Function(m) "?")
            Case Else
                strSQL = Regex.Replace(strSQL, "(@\w+)", Function(m) "Select/Insert/Update #Error DbHelper")
        End Select
        Return strSQL
    End Function


ปล. ผมมีความสุขที่เห็นคุณเขียน SourceCode ได้ถึงระดับนี้
(อย่างน้อยฯ ผมก็รู้สึกว่า ผมไม่ได้เหนื่อยล้าอยู่คนเดียว)






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-02-14 14:18:45 By : หน้าฮี
 


 

No. 2



โพสกระทู้ ( 21 )
บทความ ( 0 )



สถานะออฟไลน์


งานนี้เขาห้ามใช้ linq กันน่ะครับ ไม่งั้นอาจจะสั้นกระชับกว่านี้เยอะ
จริงๆอยากจะพัฒนา sqlHelper นี่ให้เป็น ADONetHelper
ที่สนับสนุน ทุกๆ provider แต่มันไม่ค่อยจะจำเป็นขนาดนั้น
ต่อๆไปจะเป็นยุคของ entityframework ซึ่งมันมีทุกอย่างอยู่แล้ว
ADO.NET เหมาะให้น้องๆเขาฝึกเขียนกัน และจะค่อยๆหดไปทุกที
ก็เลยเขียนสั้นๆ เอาไว้พอให้ใช้งานได้

ส่วนที่บอกว่า style โปรแกรมใกล้เคียงกันนั้นขอถือว่าเป็นคำชมนะครับ
และขออนุญาตยกความดีให้กับครูอาจารย์
ที่สู้อุตส่าห์สอนสั่งควายตัวนึงให้เขียนโปรแกรมได้มาจนทุกวันนี้
ขอบคุณครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-02-14 14:54:52 By : BIG BAD DOG
 

 

No. 3

Guest


Quote:
งานนี้เขาห้ามใช้ linq กันน่ะครับ ไม่งั้นอาจจะสั้นกระชับกว่านี้เยอะ
จริงๆอยากจะพัฒนา sqlHelper นี่ให้เป็น ADONetHelper
ที่สนับสนุน ทุกๆ provider แต่มันไม่ค่อยจะจำเป็นขนาดนั้น
ต่อๆไปจะเป็นยุคของ entityframework ซึ่งมันมีทุกอย่างอยู่แล้ว
ADO.NET เหมาะให้น้องๆเขาฝึกเขียนกัน และจะค่อยๆหดไปทุกที
ก็เลยเขียนสั้นๆ เอาไว้พอให้ใช้งานได้


งานเฉพาะกิจทำอย่างไรก็ได้เพื่อให้งานเสร็จทันกำหนดเวลา และโปรแกรมทำงานได้รวดเร็ว/มีความถูกต้องอยู่ในระดับที่เรา/ผู้ว่าจ้าง
ยอมรับได้


Quote:
ส่วนที่บอกว่า style โปรแกรมใกล้เคียงกันนั้นขอถือว่าเป็นคำชมนะครับ
และขออนุญาตยกความดีให้กับครูอาจารย์
ที่สู้อุตส่าห์สอนสั่งควายตัวนึงให้เขียนโปรแกรมได้มาจนทุกวันนี้
ขอบคุณครับ


คุณเป็นคนที่รู้จักให้และรู้จักรับ ถ้าผมเดาอนาคตของคุณไม่ผิดพลาด "ชีวิตของคุณจะไม่มีทางลดต่ำไปกว่าเดิม"


ปล. ผมพึ่งกลับมาจากทางเหนือ ตั้งใจแวะจังหวัดน่านคืนหนึ่ง (เช้าแล้วก็ไปต่อ)
เป็นบ้านไม้เก่าฯ แต่ดูดีมีระดับเกินราคา 600 บาท/คืน

ผมถามป้าเจ้าของบ้านว่า (ด้วยความสงสัย)
ผม : ป้าป้า ทำไมรั้วบ้านของป้ามันเตี้ยจัง (สูงประมาณ 50 cm จากพื้น)
ป้าป้าซึ่งเป็นคนแก่บ้านนอกคนหนึ่งตอบผมว่า : ต่อให้รั้วมันสูงแค่ไหน ถ้าคนจิตใจมันต่ำมันก็กระโดดข้าม/ปีนป่ายได้เหมือนเดิม
ผม : หัวเราะ (พึ่งกระโดดข้ามไปหยกฯ) ผมก็นอนค้างอยู่ที่จังหวัดน่านต่ออีก 2 คืน
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-02-14 18:41:46 By : หน้าฮี
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : SQL INSTANCENAME DISCOVERY หา instance ของ sqlserver ของเครื่องคอมพิวเตอร์ แก้ปัญหา connect ไม่เจอ ย้ายเครื่อง ฯ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่